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 = '男';  
相关推荐
Wilber的技术分享7 分钟前
【LeetCode高频手撕题 2】面试中常见的手撕算法题(小红书)
笔记·算法·leetcode·面试
愚昧之山绝望之谷开悟之坡35 分钟前
合格境外投资者
笔记
色空大师1 小时前
【网站搭建实操(一)环境部署】
java·linux·数据库·mysql·网站搭建
亚历克斯神1 小时前
Flutter for OpenHarmony: Flutter 三方库 mutex 为鸿蒙异步任务提供可靠的临界资源互斥锁(并发安全基石)
android·数据库·安全·flutter·华为·harmonyos
IAUTOMOBILE1 小时前
用Python批量处理Excel和CSV文件
jvm·数据库·python
常利兵2 小时前
Spring项目新姿势:Lambda封装Service调用,告别繁琐注入!
java·数据库·spring
liqianpin12 小时前
MySQL官网驱动下载(jar包驱动和ODBC驱动)【详细教程】
数据库·mysql
寒秋花开曾相惜2 小时前
(学习笔记)3.8 指针运算(3.8.3 嵌套的数组& 3.8.4 定长数组)
java·开发语言·笔记·学习·算法
kgduu3 小时前
js之客户端存储
javascript·数据库·oracle
light blue bird3 小时前
原生控件GDI完成作业协同界面
jvm·数据库·.net·winform·gdi+界面