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 = '男';  
相关推荐
krielwus1 分钟前
Oracle 11g R2 物理冷备操作文档
数据库·oracle
大气层煮月亮4 分钟前
Oracle EBS ERP之报表开发—嵌入Web中的报表预览、报表打印
前端·数据库·oracle
会挠头但不秃4 分钟前
Redis数据结构和常用命令
数据库·redis·缓存
楠目5 分钟前
SQL注入与防御:从攻击原理到预编译防御
数据库·sql
无名前端小白6 分钟前
Oracle 转 PostgreSQL, ora2pg docker compose 简单实践版
数据库·postgresql·oracle
庸人自扰612 小时前
Redis从零讲解
数据库·redis·缓存
lypzcgf3 小时前
Coze源码分析-资源库-删除数据库-后端源码-领域服务/数据访问层
数据库·go·coze·coze源码分析·智能体平台·ai应用平台·agent平台
cqsztech3 小时前
oracle linux 10 +pg18 源码安装要点
linux·数据库·oracle
健康平安的活着3 小时前
spring事务传播级别的实操案例2
数据库
安审若无3 小时前
Oracle 闪回过期后的解决方法
数据库·oracle