SQL 基础语法复习

SQL 基础语法复习

1. 查询 SELECT

查询所有列:

sql 复制代码
SELECT *
FROM 表名;

查询指定列:

sql 复制代码
SELECT 列1, 列2
FROM 表名;

带条件查询:

sql 复制代码
SELECT 列1, 列2
FROM 表名
WHERE 条件;

去重查询:

sql 复制代码
SELECT DISTINCT 列名
FROM 表名;

2. 条件 WHERE

比较条件:

sql 复制代码
WHERE 列名 = 值
WHERE 列名 <> 值
WHERE 列名 > 值
WHERE 列名 >= 值
WHERE 列名 < 值
WHERE 列名 <= 值

多个条件:

sql 复制代码
WHERE 条件1 AND 条件2
WHERE 条件1 OR 条件2

范围查询:

sql 复制代码
WHERE 列名 BETWEEN 值1 AND 值2;

集合查询:

sql 复制代码
WHERE 列名 IN (值1, 值2, 值3);

模糊查询:

sql 复制代码
WHERE 列名 LIKE '%关键字%';

空值查询:

sql 复制代码
WHERE 列名 IS NULL;
WHERE 列名 IS NOT NULL;

3. 增 INSERT

插入一整行:

sql 复制代码
INSERT INTO 表名
VALUES (值1, 值2, 值3);

指定字段插入:

sql 复制代码
INSERT INTO 表名(列1, 列2, 列3)
VALUES (值1, 值2, 值3);

把查询结果插入表:

sql 复制代码
INSERT INTO 表名(列1, 列2)
SELECT 列1, 列2
FROM 另一个表
WHERE 条件;

4. 删 DELETE

删除指定记录:

sql 复制代码
DELETE FROM 表名
WHERE 条件;

删除所有记录:

sql 复制代码
DELETE FROM 表名;

清空表:

sql 复制代码
TRUNCATE TABLE 表名;

区别:

text 复制代码
DELETE 可以带 WHERE,能删部分数据。
TRUNCATE 不能带 WHERE,一次清空整张表。

5. 改 UPDATE

修改指定记录:

sql 复制代码
UPDATE 表名
SET 列名 = 新值
WHERE 条件;

一次修改多个字段:

sql 复制代码
UPDATE 表名
SET 列1 = 新值1,
    列2 = 新值2
WHERE 条件;

注意:

text 复制代码
UPDATE 和 DELETE 不写 WHERE,会影响整张表。

6. 排序 ORDER BY

升序:

sql 复制代码
SELECT *
FROM 表名
ORDER BY 列名 ASC;

降序:

sql 复制代码
SELECT *
FROM 表名
ORDER BY 列名 DESC;

多个字段排序:

sql 复制代码
SELECT *
FROM 表名
ORDER BY 列1 ASC, 列2 DESC;

说明:

text 复制代码
ASC:升序,默认可以不写
DESC:降序

7. 聚合函数

统计个数:

sql 复制代码
SELECT COUNT(*)
FROM 表名;

求和:

sql 复制代码
SELECT SUM(列名)
FROM 表名;

平均值:

sql 复制代码
SELECT AVG(列名)
FROM 表名;

最大值:

sql 复制代码
SELECT MAX(列名)
FROM 表名;

最小值:

sql 复制代码
SELECT MIN(列名)
FROM 表名;

常用聚合函数:

text 复制代码
COUNT:统计数量
SUM:求总和
AVG:求平均值
MAX:求最大值
MIN:求最小值

8. 分组 GROUP BY

按某列分组统计:

sql 复制代码
SELECT 分组列, 聚合函数(列)
FROM 表名
GROUP BY 分组列;

例子:

sql 复制代码
SELECT XSBH, SUM(JE) AS 销售总金额
FROM XSCP
GROUP BY XSBH;

多列分组:

sql 复制代码
SELECT 列1, 列2, COUNT(*)
FROM 表名
GROUP BY 列1, 列2;

规则:

text 复制代码
SELECT 中的普通字段,必须出现在 GROUP BY 中。
没有出现在 GROUP BY 中的字段,必须放进聚合函数。

9. 分组后筛选 HAVING

sql 复制代码
SELECT 分组列, 聚合函数(列)
FROM 表名
GROUP BY 分组列
HAVING 聚合条件;

例子:

sql 复制代码
SELECT XSBH, SUM(JE) AS 销售总金额
FROM XSCP
GROUP BY XSBH
HAVING SUM(JE) >= 10000;

区别:

text 复制代码
WHERE:分组前筛选普通记录
HAVING:分组后筛选统计结果

10. 分组 + 排序

sql 复制代码
SELECT 分组列, 聚合函数(列) AS 别名
FROM 表名
GROUP BY 分组列
ORDER BY 聚合函数(列) DESC;

例子:

sql 复制代码
SELECT XSBH, SUM(JE) AS 销售总金额
FROM XSCP
GROUP BY XSBH
ORDER BY SUM(JE) DESC;

也可以用别名排序:

sql 复制代码
SELECT XSBH, SUM(JE) AS 销售总金额
FROM XSCP
GROUP BY XSBH
ORDER BY 销售总金额 DESC;

11. 连接查询

旧式写法:

sql 复制代码
SELECT 表1.列, 表2.列
FROM 表1, 表2
WHERE 表1.关联列 = 表2.关联列;

标准写法:

sql 复制代码
SELECT 表1.列, 表2.列
FROM 表1
JOIN 表2 ON 表1.关联列 = 表2.关联列;

三表连接:

sql 复制代码
SELECT *
FROM 表1
JOIN 表2 ON 表1.关联列 = 表2.关联列
JOIN 表3 ON 表2.关联列 = 表3.关联列;

12. 子查询

作为条件:

sql 复制代码
SELECT *
FROM 表名
WHERE 列名 IN (
    SELECT 列名
    FROM 另一个表
);

比较平均值:

sql 复制代码
SELECT *
FROM SC sc1
WHERE Grade >= (
    SELECT AVG(Grade)
    FROM SC sc2
    WHERE sc2.Sno = sc1.Sno
);

EXISTS:

sql 复制代码
SELECT *
FROM 表1
WHERE EXISTS (
    SELECT *
    FROM 表2
    WHERE 表2.关联列 = 表1.关联列
);

NOT EXISTS:

sql 复制代码
SELECT *
FROM 表1
WHERE NOT EXISTS (
    SELECT *
    FROM 表2
    WHERE 表2.关联列 = 表1.关联列
);

13. 集合查询

并集:

sql 复制代码
SELECT 列名 FROM 表1
UNION
SELECT 列名 FROM 表2;

交集:

sql 复制代码
SELECT 列名 FROM 表1
INTERSECT
SELECT 列名 FROM 表2;

差集:

sql 复制代码
SELECT 列名 FROM 表1
EXCEPT
SELECT 列名 FROM 表2;

说明:

text 复制代码
UNION:合并并去重
INTERSECT:取共同部分
EXCEPT:前者有、后者没有

14. 常用完整顺序

sql 复制代码
SELECT 列名, 聚合函数(列)
FROM 表名
WHERE 普通条件
GROUP BY 分组列
HAVING 聚合条件
ORDER BY 排序列 ASC/DESC;

执行理解:

text 复制代码
FROM:从哪张表来
WHERE:先筛选记录
GROUP BY:再分组
HAVING:筛选分组后的结果
SELECT:显示结果
ORDER BY:最后排序

15. 记忆口诀

text 复制代码
查:SELECT FROM WHERE
增:INSERT INTO VALUES
删:DELETE FROM WHERE
改:UPDATE SET WHERE
分组:GROUP BY
组后筛选:HAVING
排序:ORDER BY
相关推荐
ULIi096kr1 小时前
MySQL磁盘爆满快速排查方案:一键查询库表空间、定位占用大户(RDS/自建通用)
数据库·mysql
华山令狐虫1 小时前
告别手写 SQL——DBAPI 企业版 v4.6.0 推出 AI 助手
数据库·人工智能·sql·dbapi
Cx330❀1 小时前
【MySQL基础】库与表的全面操纵指南
linux·服务器·网络·数据库·c++·mysql
天丁o1 小时前
企业 AI Agent 工程化落地:从需求边界到系统集成的 6 个环节
数据库·人工智能
涛思数据(TDengine)1 小时前
从时序数据库到工业AI:涛思数据参编“人工智能+工业软件”评价规范,推动工业数据标准
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据·工业数据库
点灯小铭1 小时前
基于51单片机的LED点阵汉字显示系统设计
数据库·单片机·嵌入式硬件·毕业设计·51单片机·课程设计·期末大作业
SilentSamsara1 小时前
DuckDB + Python:嵌入式 OLAP 数据库的轻量分析实战
开发语言·数据库·python·微服务
Nturmoils2 小时前
从 MySQL 到 KingbaseES:Database、Schema、User 一次讲透
数据库·后端
我是一颗柠檬2 小时前
【Redis】Redis面试高频考点汇总Day15(2026年)
数据库·redis·缓存·面试