子查询:让SQL像俄罗斯套娃一样嵌套!|转行学DB第8天

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 数据库小学妹带你轻松入门子查询!用“SELECT里套SELECT”,像俄罗斯套娃一样,一步解决“先算平均分、再查高分学生”等两步难题。支持WHERE(条件筛选)、FROM(临时表)、SELECT(标量列)三种用法,简洁直观,新手友好~

一个SELECT里再套一个SELECT,解决“先查再查”的难题

大家好呀!我是​数据库小学妹​👋

前面我们学会了单表查询、多表关联(JOIN)、分组统计。今天我又遇到了新的难点:如果我想查询:

“考试成绩高于全班平均分的同学有哪些?”

难道要分两步?先算平均分,再把高于平均分的同学查询出来?其实并不用这么麻烦,数据库中的子查询可以像俄罗斯套娃一样,一个查询里面再套一个查询。


一、什么是子查询?一句话讲清楚

子查询就是嵌套在另一个SQL语句里的查询。它的结果被外层查询当作条件或数据源来用。

语法长这样:

SELECT 列名 FROM 表名 
WHERE 列名 操作符 (SELECT 列名 FROM 表名 WHERE 条件);

括号里的 SELECT ... 就是子查询,它会先执行,把结果返回给外层。

💡 就像你先问“全班平均分是多少”,然后拿着这个数去查“谁高于它”。只不过子查询把这两步合并成一步了。


二、子查询的三大使用场景

2.1 WHERE型子查询:最常用的一种

把子查询放在 WHERE 后面,作为筛选条件。

📚场景1:查高于平均分的学生

SELECT name, score 
FROM scores 
WHERE score > (SELECT AVG(score) FROM scores);

执行顺序:

  1. 先执行子查询 SELECT AVG(score) FROM scores,假设结果是85
  2. 外层变成 WHERE score > 85,查出来分数大于85的人

📚场景2:查有成绩的学生(用IN)

SELECT name FROM students 
WHERE id IN (SELECT DISTINCT student_id FROM scores);

子查询先查出所有有成绩的学生ID,然后外层找这些ID对应的学生姓名。

注意: IN 适合子查询返回多个值。= 只能用于子查询返回单个值。


2.2 FROM型子查询:把查询结果当成一张临时表

子查询放在 FROM 后面,相当于先查出一张“临时表”,外层再从这个临时表里查。

📚场景:查每个班级的平均分,再找出平均分>90的班级

SELECT class, avg_score
FROM (
    SELECT class, AVG(score) as avg_score
    FROM scores
    GROUP BY class
) AS temp
WHERE avg_score > 90;

内层子查询先算出每个班级的平均分,外层再筛选。

💡 给子查询起别名(AS temp)是必须的,不然数据库不认识这张“临时表”。

2.3 SELECT子句中的子查询:把查询结果作为输出列

子查询放在 SELECT 后面,作为​输出的一列​。这种子查询必须​只返回一个值​(一行一列),所以叫​标量子查询​。

📚场景:查每个学生的成绩,同时带上全班平均分作为对比

SELECT 
    name, 
    score,
    (SELECT AVG(score) FROM scores) AS class_avg
FROM scores;

结果:

name score class_avg
小明 90 85
小红 85 85
小刚 92 85

每一行都多了一列“全班平均分”,方便对比自己是否高于平均。

📚更实用的场景:查每个学生的成绩,同时带上该生所在班级的平均分

这时候子查询需要​关联外层​(叫“相关子查询”):

SELECT 
    name,
    score,
    (SELECT AVG(score) 
     FROM scores s2 
     WHERE s2.class = s1.class) AS class_avg
FROM scores s1;

💡 这种写法稍微复杂,新手可以先掌握不关联外层的标量子查询,等熟练了再学关联版本。


三、子查询 vs JOIN:什么时候用哪个?

很多场景既能用子查询也能用JOIN,我纠结了好久。后来总结了这条原则:

image_078252916671639.png

比如查“有成绩的学生”,用 IN 子查询和 INNER JOIN 都能实现:

-- 子查询写法
SELECT * FROM students WHERE id IN (SELECT student_id FROM scores);

-- JOIN写法
SELECT DISTINCT students.* 
FROM students 
INNER JOIN scores ON students.id = scores.student_id;

两种都可以,看个人习惯。我一般喜欢用JOIN,因为不用记 IN= 的区别。


四、新手避坑指南

image_294842610597654.png


五、今日学习心得

今天的内容总结成三句话:

  1. 子查询就是查询里的查询,先内后外,像俄罗斯套娃
  2. WHERE型:子查询当条件;FROM型:子查询当临时表
  3. 子查询和JOIN各有优劣,简单场景用子查询,复杂或大数据量用JOIN

虽然子查询用起来感觉更提升效率,不用写两句SQL,但是子查询写多了性能会下载,特别是数据量大的时候。那该怎么办呢?明天我们来学习优化办法。


👋 我是数据库小学妹,一个从设计转行数据库的菜鸟。我们一起,把复杂的技术变得简单有趣!💪


本文为个人学习总结,所有命令均在MySQL 8.0环境下验证。子查询虽好用,但别嵌套太深,否则自己都绕晕了。

相关文章
|
1月前
|
SQL 数据库
多表关联查询入门:LEFT JOIN、INNER JOIN一文搞懂|转行学DB第6天
本文通俗易懂地讲解了数据库多表查询的三种JOIN操作:INNER JOIN(内连接)只返回两表匹配的数据,适用于查询交集数据;LEFT JOIN(左连接)保留左表所有记录并匹配右表数据,适用于查询主表完整信息;RIGHT JOIN(右连接)则保留右表所有记录。
|
26天前
|
SQL 关系型数据库 MySQL
数据量大查询慢?索引让你的SQL秒级响应!|转行学DB第9天
用生活化比喻(如字典目录)详解索引原理:它通过B+树结构加速查询,避免全表扫描;涵盖创建、查看、删除索引方法,联合索引的最左前缀原则,以及读写平衡等实战要点——让查询从“等几秒”变“秒出”!
数据量大查询慢?索引让你的SQL秒级响应!|转行学DB第9天
|
1月前
|
存储 自然语言处理 机器人
OpenClaw 搭团队太折腾?这个 Skill 一键搞定多智能体协作
OpenClaw是专为多智能体协作设计的基座,采用Actor架构,各Agent独立运行、消息驱动。针对协作失序、配置复杂等痛点,agentrun-team Skill提供一键组队能力:自动完成身份配置、构建团队意识与闭环流程,10分钟即可交付可协同、可审计、高透明的智能体团队。
|
1月前
|
SQL NoSQL 关系型数据库
数据库分类一次讲清|转行学DB第2天
数据库小学妹(UI转行萌新)用通俗语言拆解数据库分类:从关系型(MySQL/Oracle)、NoSQL(Redis/MongoDB/Cassandra)、NewSQL(TiDB)到2026年爆火的向量数据库(Pinecone/Milvus),按数据模型、部署架构、业务负载三大维度梳理,配场景化案例与选学路径,助新手轻松入门。
|
2月前
|
人工智能 安全 前端开发
阿里开源 Team 版 OpenClaw,5分钟完成本地安装
HiClaw 是 OpenClaw 的升级版,通过引入 Manager Agent 架构和分布式设计,解决了 OpenClaw 在安全性、多任务协作、移动端体验、记忆管理等方面的核心痛点。
2188 60
阿里开源 Team 版 OpenClaw,5分钟完成本地安装
|
18天前
|
SQL 关系型数据库 MySQL
SQL优化十大技巧,查询速度提升10倍!
数据库小学妹带你轻松提速SQL!10个实战优化技巧:精简SELECT、善用LIMIT、巧用EXPLAIN、合理建索引、避开函数索引失效、JOIN优于子查询、IN替代OR、批量操作、EXISTS优化大子查询、定期OPTIMIZE。附避坑指南,新手也能秒上手!
|
18天前
|
存储 JSON 缓存
告别数据混乱!数据库设计三范式从入门到实践
数据库小学妹带你轻松入门三范式!用“建房打地基”比喻,讲清1NF(列不可分)、2NF(消除部分依赖)、3NF(消除传递依赖),直击数据冗余、更新异常等痛点。附实战拆表案例与反范式化提醒,助你设计出结构清晰、稳定高效的数据库!
|
20天前
|
SQL 关系型数据库 MySQL
5款好用的免费MySQL客户端,新手必备!
告别枯燥命令行!数据库小学妹精选5款免费MySQL图形化工具:Workbench(官方全能)、phpMyAdmin(免安装Web版)、DBeaver(多库支持)、HeidiSQL(Windows轻量之选)、TablePlus(高颜值跨平台)。小白友好,语法高亮、自动补全、可视化结构一应俱全,助你高效学SQL!
|
20天前
|
SQL 人工智能 安全
AI圈开始“养马”了?聊聊龙虾退位、爱马仕登基
AI智能体“龙虾”(OpenClaw)的衰落与“爱马仕”(Hermes Agent)的崛起:前者因API限策与高危漏洞(CVSS 9.9)式微;后者以持久记忆、技能自生成、跨平台互通等实用能力破圈,成技术圈新“拐杖”。但技术无银弹,懂你的工具才是真助力。