news 2025/12/24 10:26:21

常用的 SQL 语句分类及其语法:

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
常用的 SQL 语句分类及其语法:

好的,以下是常用的 SQL 语句分类及其语法:

1. 数据查询 (SELECT)

  • 基本查询:
    SELECT 列名1, 列名2, ... FROM 表名;
    • 查询所有列:SELECT * FROM 表名;
    • 查询表数据:SELECT COUNT(*) FROM 表名
  • 带条件查询 (WHERE):
    SELECT 列名1, 列名2, ... FROM 表名 WHERE 条件;
    • 条件运算符:=,!=<>,>,<,>=,<=
    • 逻辑运算符:AND,OR,NOT
    • 范围查询:BETWEEN 值1 AND 值2
    • 列表匹配:IN (值1, 值2, ...)
    • 模糊匹配:LIKE '模式'(通配符%代表任意多个字符,_代表一个字符)
    • 空值判断:IS NULL,IS NOT NULL
  • 结果排序 (ORDER BY):
    SELECT 列名1, 列名2, ... FROM 表名 ORDER BY 排序列1 [ASC|DESC], 排序列2 [ASC|DESC], ...;
    • ASC升序 (默认),DESC降序。
  • 结果去重 (DISTINCT):
    SELECT DISTINCT 列名 FROM 表名;
  • 结果限制 (LIMIT):
    SELECT 列名1, 列名2, ... FROM 表名 LIMIT 数量; -- 取前 N 条 SELECT 列名1, 列名2, ... FROM 表名 LIMIT 偏移量, 数量; -- 分页常用
  • 聚合函数 (GROUP BY, HAVING):
    SELECT 聚合函数(列名), 分组列 FROM 表名 GROUP BY 分组列 HAVING 分组后条件;
    • 常用聚合函数:COUNT(),SUM(),AVG(),MAX(),MIN()
    • GROUP BY按指定列分组。
    • HAVING对分组后的结果进行过滤 (类似WHERE,但作用于分组)。
  • 表连接 (JOIN):
    • 内连接 (INNER JOINJOIN):
      SELECT 列名 FROM 表1 INNER JOIN 表2 ON 表1.关联列 = 表2.关联列;
    • 左外连接 (LEFT JOINLEFT OUTER JOIN):
      SELECT 列名 FROM 表1 LEFT JOIN 表2 ON 表1.关联列 = 表2.关联列;
    • 右外连接 (RIGHT JOINRIGHT OUTER JOIN):
      SELECT 列名 FROM 表1 RIGHT JOIN 表2 ON 表1.关联列 = 表2.关联列;
    • 全外连接 (FULL JOINFULL OUTER JOIN):
      SELECT 列名 FROM 表1 FULL JOIN 表2 ON 表1.关联列 = 表2.关联列;
    • 交叉连接 (CROSS JOIN):
      SELECT 列名 FROM 表1 CROSS JOIN 表2;

2. 数据操作 (INSERT, UPDATE, DELETE)

  • 插入数据 (INSERT):
    INSERT INTO 表名 (列名1, 列名2, ...) VALUES (值1, 值2, ...); -- 插入单条 INSERT INTO 表名 (列名1, 列名2, ...) VALUES (值1, 值2, ...), (值1, 值2, ...), ...; -- 插入多条 INSERT INTO 表名 SELECT 列名1, 列名2, ... FROM 另一表名 [WHERE 条件]; -- 从查询结果插入
  • 更新数据 (UPDATE):
    UPDATE 表名 SET 列名1 = 新值1, 列名2 = 新值2, ... WHERE 条件; -- 一定要加WHERE条件避免全表更新!
  • 删除数据 (DELETE):
    DELETE FROM 表名 WHERE 条件; -- 一定要加WHERE条件避免清空表!
  • 清空表数据 (TRUNCATE):
    TRUNCATE TABLE 表名; -- 删除所有数据,重置自增ID等,速度快但不可回滚

3. 数据定义 (CREATE, ALTER, DROP)

  • 创建数据库:
    CREATE DATABASE 数据库名;
  • 删除数据库:
    DROP DATABASE 数据库名;
  • 创建表:
    CREATE TABLE 表名 ( 列名1 数据类型 [约束], 列名2 数据类型 [约束], ... [表级约束] );
    • 常用数据类型:INT,VARCHAR(长度),TEXT,DATE,DATETIME,DECIMAL(总位数, 小数位数),BOOLEAN等。
    • 常用约束:
      • PRIMARY KEY(主键)
      • NOT NULL(非空)
      • UNIQUE(唯一)
      • FOREIGN KEY (外键列) REFERENCES 主表名(主键列)(外键)
      • CHECK (条件)(检查约束)
      • DEFAULT 默认值(默认值)
  • 修改表结构 (ALTER):
    ALTER TABLE 表名 ADD 列名 数据类型 [约束]; -- 添加列 ALTER TABLE 表名 DROP COLUMN 列名; -- 删除列 ALTER TABLE 表名 MODIFY COLUMN 列名 新数据类型 [新约束]; -- 修改列定义 ALTER TABLE 表名 RENAME COLUMN 旧列名 TO 新列名; -- 重命名列 (部分数据库) ALTER TABLE 表名 ADD CONSTRAINT 约束名 约束定义; -- 添加约束 (如外键) ALTER TABLE 表名 DROP CONSTRAINT 约束名; -- 删除约束
  • 删除表:
    DROP TABLE 表名;

4. 数据控制 (GRANT, REVOKE)

  • 授予权限:
    GRANT 权限列表 ON 数据库对象 TO 用户或角色 [WITH GRANT OPTION];
    • 权限列表:SELECT,INSERT,UPDATE,DELETE,ALL PRIVILEGES等。
    • 数据库对象:表名,视图名,数据库名.*等。
  • 撤销权限:
    REVOKE 权限列表 ON 数据库对象 FROM 用户或角色;

5. 其他常用

  • 创建视图 (VIEW):
    CREATE VIEW 视图名 AS SELECT 语句;
  • 创建索引 (INDEX):
    CREATE INDEX 索引名 ON 表名 (列名); -- 单列索引 CREATE INDEX 索引名 ON 表名 (列名1, 列名2); -- 组合索引
    • 索引可加速查询,但会增加插入、更新、删除的开销,需权衡使用。

这些是 SQL 中最常用的一些语句。具体语法细节可能因数据库管理系统(如 MySQL, PostgreSQL, SQL Server, Oracle)的不同而略有差异。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/23 16:22:11

Unity3D制作《类王者荣耀》爆款手游系列课程

# Unity3D 实战&#xff1a;从Demo到类《王者荣耀》的工程化开发## 一、认知升级&#xff1a;从Demo思维到产品思维真正的游戏开发不是“能跑就行”&#xff0c;而是**构建健壮、可扩展、可维护的工程系统**。类《王者荣耀》这样的MOBA游戏&#xff0c;看似是“几个英雄对打”&…

作者头像 李华
网站建设 2025/12/23 17:16:20

2025如何选择适合企业需求的舆情监测服务商?5大维度评估TOP服务商

当企业面对信息爆炸的时代&#xff0c;一条短视频可能在30分钟内重创上市公司市值&#xff0c;一条微博可能让地方机构的招商努力归零。在众多舆情服务商中做出正确选择&#xff0c;已经成为现代企业风险管理的基本功。01 行业变革与选择挑战2025年的舆情监测行业已从被动告警升…

作者头像 李华
网站建设 2025/12/23 18:20:43

RTSP模拟开发:轻松搭建本地摄像头推流

在开发中我们可能会涉及到连接摄像头的开发&#xff0c;但是在本地环境我们没有相关的连接时&#xff0c;就需要本地进行模拟。 ✅ 推荐方案&#xff1a;使用 RTSP Simple Server&#xff08;RSS&#xff09; 这是一个用 Go 写的超轻量、零依赖、单文件 RTSP 服务器&#xff…

作者头像 李华
网站建设 2025/12/23 12:59:35

Pock:重新定义MacBook触控栏的终极解决方案

Pock&#xff1a;重新定义MacBook触控栏的终极解决方案 【免费下载链接】pock Widgets manager for MacBook Touch Bar 项目地址: https://gitcode.com/gh_mirrors/po/pock 你是否曾经觉得MacBook的Touch Bar功能有限&#xff0c;无法充分发挥其潜力&#xff1f;Pock作为…

作者头像 李华
网站建设 2025/12/23 20:56:55

面对市场上的RPA软件如何选择?

选择RPA数据采集工具时&#xff0c;建议您根据具体业务场景、对稳定性和安全性的要求、以及操作便捷性等因素进行综合考量。没有“最好”的工具&#xff0c;只有最适合您需求的方案。如果追求极致易用和电商适配&#xff0c;影刀RPA是首选&#xff1b;金融领域看重安全稳定&…

作者头像 李华
网站建设 2025/12/23 21:09:47

Swin Transformer重塑目标检测:从效率瓶颈到性能突破的实战指南

Swin Transformer重塑目标检测&#xff1a;从效率瓶颈到性能突破的实战指南 【免费下载链接】detr End-to-End Object Detection with Transformers 项目地址: https://gitcode.com/gh_mirrors/de/detr 在计算机视觉领域&#xff0c;目标检测技术正面临前所未有的效率挑…

作者头像 李华