SQL 查询语法笔记

SQL 查询语法笔记

一、基础查询
  1. 查询所有列

    sql 复制代码
    SELECT * FROM t_student;  
  2. 指定列查询

    sql 复制代码
    SELECT id, stu_id, name, pinyin, sex, birthday FROM t_student;  
  3. 列与表别名

    • 列别名:AS 可省略
    • 表别名:用于简化前缀(无歧义时可省略表名前缀)
    sql 复制代码
    SELECT  
      t.id AS 编号,  
      t.stu_id AS 学号,  
      t.name 姓名,  -- 省略AS  
      t.pinyin 拼音  
    FROM t_student t;  -- 表别名  
  4. 列运算

    sql 复制代码
    SELECT id, stu_id, name, height + 10 AS 修正身高, weight - 10 AS 修正体重  
    FROM t_student;  
  5. 分页查询(LIMIT

    sql 复制代码
    -- 前10条  
    SELECT * FROM t_student LIMIT 10;  
    
    -- 从第10行开始取10条(行号从0开始)  
    SELECT * FROM t_student LIMIT 10, 10;  
    -- 等效写法  
    SELECT * FROM t_student LIMIT 10 OFFSET 10;  
  6. 条件筛选(WHERE

    • 比较运算符=, <>, !=, >, >=, <, <=

      sql 复制代码
      SELECT * FROM t_student WHERE id > 5;  
      SELECT * FROM t_student WHERE birthday > '2000-01-01';  -- MySQL支持日期比较  
    • 逻辑运算符AND, OR, NOT

      sql 复制代码
      SELECT * FROM t_student WHERE height >= 175 AND sex = '女';  
    • 空值判断

      sql 复制代码
      SELECT * FROM t_student WHERE class_id IS NULL;  -- 空值  
      SELECT * FROM t_student WHERE class_id IS NOT NULL;  -- 非空  
    • 模糊查询(LIKE

      • %:匹配0个或多个字符
      • _:匹配1个字符
      sql 复制代码
      SELECT * FROM t_student WHERE name LIKE '张%';  -- 姓张  
      SELECT * FROM t_student WHERE name LIKE '%晓%';  -- 包含"晓"  
      SELECT * FROM t_student WHERE name LIKE '张__';  -- 姓张且3个字  
    • 正则查询

      sql 复制代码
      SELECT * FROM t_student WHERE name REGEXP '\\w{4,}';  -- 匹配4+位字符  
      SELECT * FROM t_student WHERE wechat NOT RLIKE '\\d{11}';  -- 非11位数字  
  7. 结果去重(DISTINCT

    sql 复制代码
    SELECT DISTINCT sex FROM t_student;  -- 慎用(影响性能)  
  8. 结果排序(ORDER BY

    • ASC:升序(默认),DESC:降序
    sql 复制代码
    SELECT * FROM t_student ORDER BY height;  -- 身高升序  
    SELECT * FROM t_student ORDER BY weight DESC;  -- 体重降序  
    -- 多列排序:先按身高升序,再按体重降序  
    SELECT * FROM t_student ORDER BY height ASC, weight DESC;  

二、分组查询(GROUP BY
  1. 基本分组

    sql 复制代码
    SELECT sex, AVG(height) FROM t_student GROUP BY sex;  
    SELECT class_id, MAX(height), MIN(weight), COUNT(*) FROM t_student GROUP BY class_id;  
  2. 多列分组

    sql 复制代码
    SELECT class_id, sex, MAX(height), MAX(weight)  
    FROM t_student  
    GROUP BY class_id, sex;  
  3. 聚合函数注意事项

    • COUNT(*):统计所有行(包括NULL
    • COUNT(列名):统计非NULL
    • COUNT(DISTINCT 列名):去重统计
    sql 复制代码
    SELECT COUNT(*) FROM t_student;  -- 总行数  
    SELECT COUNT(class_id) FROM t_student;  -- 非NULL的class_id数量  
    SELECT COUNT(DISTINCT class_id) FROM t_student;  -- 去重统计  
  4. 分组后筛选(HAVING

    • WHERE:分组前筛选
    • HAVING:分组后筛选(可引用聚合结果)
    sql 复制代码
    SELECT class_id, sex, MAX(height) AS max_height  
    FROM t_student  
    WHERE height > 180  -- 分组前条件  
    GROUP BY class_id, sex  
    HAVING max_height > 183;  -- 分组后条件  

三、子查询
  1. 标量子查询(SELECT子句)

    sql 复制代码
    SELECT id, name, (SELECT class_name FROM t_class WHERE id = t_student.class_id)  
    FROM t_student;  
  2. 表子查询(FROM子句)

    sql 复制代码
    SELECT *  
    FROM (SELECT * FROM t_student WHERE sex = '女') AS women_students;  -- 必须起别名  
  3. WHERE子查询

    • 单值比较

      sql 复制代码
      SELECT * FROM t_student  
      WHERE class_id = (SELECT id FROM t_class WHERE class_name = '080503-JAVA');  
    • 多值比较

      sql 复制代码
      -- 大于所有子查询结果(> ALL)  
      SELECT * FROM t_student  
      WHERE class_id > ALL(SELECT id FROM t_class WHERE class_name LIKE '%JAVA%');  
      
      -- 大于任意子查询结果(> ANY)  
      SELECT * FROM t_student  
      WHERE class_id > ANY(SELECT id FROM t_class WHERE class_name LIKE '%JAVA%');  
    • 成员判断(IN/NOT IN

      sql 复制代码
      SELECT * FROM t_student WHERE id IN (1, 2, 3);  
      SELECT * FROM t_student  
      WHERE class_id IN (SELECT id FROM t_class WHERE class_name LIKE '%JAVA%');  
    • 存在性判断(EXISTS

      sql 复制代码
      SELECT * FROM t_student  
      WHERE EXISTS (SELECT 1 FROM t_class WHERE class_name LIKE '%JAVA%');  
  4. 相关子查询

    sql 复制代码
    -- 查询身高高于班级平均身高的学生  
    SELECT *  
    FROM t_student t1  
    WHERE height > (  
      SELECT AVG(height)  
      FROM t_student t2  
      WHERE t2.class_id = t1.class_id  -- 引用外层表字段  
    );  

四、表连接
  1. 内连接(INNER JOIN

    • 仅返回匹配的行
    sql 复制代码
    SELECT s.id, s.name, c.class_name  
    FROM t_student s  
    INNER JOIN t_class c ON s.class_id = c.id;  
  2. 左外连接(LEFT JOIN

    • 左表全部显示 + 右表匹配(不匹配则为NULL
    sql 复制代码
    SELECT s.id, s.name, c.class_name  
    FROM t_student s  
    LEFT JOIN t_class c ON s.class_id = c.id;  
  3. 右外连接(RIGHT JOIN

    • 右表全部显示 + 左表匹配(不匹配则为NULL
    sql 复制代码
    SELECT s.id, s.name, c.class_name  
    FROM t_student s  
    RIGHT JOIN t_class c ON s.class_id = c.id;  
  4. 全外连接(MySQL通过UNION实现)

    sql 复制代码
    (SELECT * FROM t_student s LEFT JOIN t_class c ON s.class_id = c.id)  
    UNION  
    (SELECT * FROM t_student s RIGHT JOIN t_class c ON s.class_id = c.id);  

五、联合查询(UNION
  • 注意事项
    1. 各查询的列数必须一致
    2. 数据类型需兼容
    3. UNION 去重,UNION ALL 不去重
sql 复制代码
-- 合并男学生记录(去重)  
SELECT id, name FROM t_student WHERE sex = '男'  
UNION  
SELECT id, name FROM t_student WHERE sex = '男';  

-- 合并男学生记录(不去重)  
SELECT id, name FROM t_student WHERE sex = '男'  
UNION ALL  
SELECT id, name FROM t_student WHERE sex = '男';  
相关推荐
不良人天码星1 分钟前
redis的事务,以及watch的原理
数据库·redis·缓存
韩立学长10 分钟前
基于微信小程序的公益捐赠安全平台9hp4t247 包含完整开发套件(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·微信小程序·小程序
智能化咨询13 分钟前
SQL之参数类型讲解——从基础类型到动态查询的核心逻辑
数据库·oracle
doris820413 分钟前
使用Yum安装Redis
数据库·redis·缓存
有一个好名字16 分钟前
万字 Apache ShardingSphere 完全指南:从分库分表到分布式数据库生态
数据库·分布式·apache
峰顶听歌的鲸鱼26 分钟前
1.云计算与服务器基础
运维·服务器·笔记·云计算·学习方法
Boilermaker199234 分钟前
【Redis】哨兵与对脑裂的情况分析
数据库·redis·缓存
Kay_Liang39 分钟前
大语言模型如何精准调用函数—— Function Calling 系统笔记
java·大数据·spring boot·笔记·ai·langchain·tools
橘 日向39 分钟前
admin二维码字符过长导致显示失败问题
数据库·oracle
bnsarocket1 小时前
Verilog和FPGA的自学笔记7——流水灯与时序约束(XDC文件的编写)
笔记·fpga开发