网站首页 > 技术文章 正文
大家好,我是宁一。
今天讲解SQL教程第18课:子查询。
SQL语句可以嵌套,最常见的就是查询语句的嵌套。
基本语法:
SELECT <字段名>
FROM <表名>
WHERE(
SELECT <字段名>
FROM <表名>
);
我们一般称外面嵌套的语句为主查询,里面被嵌套的语句为子查询,有时也会叫外查询、内查询,大家知道意思就好。
子查询要用括号括起来。子查询不仅可以放在WHERE的后面,还可以放在SELECT、FROM的后面,我们一个个来讲解。
1、子查询+WHERE子句
SQL执行时,会先执行括号内的子查询,子查询最常与WHERE子句结合使用。子查询的结果作为WHERE子句的筛选条件,完成更复杂的数据检索。
实例:在Students表中,找出所有在"宁一"后面出生的学生。
实例解析:需要先确定"宁一"的生日,再将生日作为WHERE筛选条件,得到最终数据。
第一步:找到"宁一"的生日
SELECT Sage
FROM Students
WHERE Sname = "宁一"
第二步:将生日作为WHERE筛选条件,得到最终数据,子查询语句要用括号括起来。
SELECT *
FROM Students
WHERE Sage > (
SELECT Sage
FROM Students
WHERE Sname = "宁一"
)
2、子查询 + SELECT 语句
子查询还可以与 SELECT 语句结合使用,子查询返回的结果,会作为列显示在结果集中。
SELECT语句的子查询经常与聚合函数结合使用。因为我们使用聚合函数的时候,记录会合成一条,其它数据细节就不能显示了。
比如:我们想要查看学生表中所有的学生姓名、学生生日、学生的最大生日。
示例结果:
错误写法:
SELECT Sname,Sage,Max(Sage)
FROM Students
像上面这样写是会报错的,因为聚合函数与其他表中的列(Sname,Sage),同时放在SELECT的后面。需要用GROUP BY语句将这些表中的列(Sname,Sage)分组。
上面的语句后面加上 GROUP BY Sname,Sage 就可以了。
但是这样写,会将每组的数据聚合成1条数据,比如每组有3条数据,使用聚合函数MAX()+GROUP BY,最终每组只会显示1条最大值的数据。
我们需要展现Students表中所有的学生,这样写不能满足我们的需求。
正确写法:结合子查询来实现。
SELECT
Sname,
Sage,
(SELECT Max(Sage) FROM Students) AS Maxage
FROM Students
3、子查询+FROM子句
子查询与FROM子句结合使用,子查询结果被当成了一个“表”,可以用SELECT语句做进一步的筛查。
比如:我们先写一个SELECT查询语句
SELECT
Sid,
'student' AS status
FROM Students
WHERE Sid <= 5
将上面的查询语句放在FROM的后面,则上面查询到的结果,就会被当成一个“表”。
SELECT Sid,status
FROM (
SELECT
Sid,
'student' AS status
FROM Students
WHERE Sid <= 5
) AS s -- 必须加别名
WHERE Sid > 2
这里有一个特别要注意的地方,放在FROM后面的子查询,必须要加别名。
复杂的子查询再嵌套进 FROM 里会让整个查询看起来过于复杂,我们一般会将子查询结果储存为视图,然后再直接使用视图作为来源表,视图会SQL高阶课程中详细讲解。
其实子查询就是查询语句嵌套,没有什么新的东西,只是多了一个层级,由内向外地一层层梳理就会很清楚了。
作业:结合Students表,从Teachers表中找出当班主任的老师(通过子查询实现)。
作业解析:先从Students表中,找出所有班主任的Tid并去重,将查询结果作为筛选条件,放在WHERE语句中。
SELECT *
FROM Teachers
WHERE Tid IN (
SELECT
DISTINCT Tid
FROM Students
)
点击关注,更新课程第一时间通知哦~
猜你喜欢
- 2025-09-03 数据库教程-SQL Server多条件模糊查询
- 2025-09-03 数据库教程-SQL Server海量数据的快速存储
- 2025-09-03 数据库教程-SQL Server数据字典查询及导出
- 2025-09-03 利用VBA+SQL查询Excel工作表数据(基本查询)
- 2025-09-03 紫金桥组态软件基于内置SQL查询历史数据的方法
- 2025-09-03 【开源推荐】SQL 审核查询平台Archery v1.7.9 发布,数据可归档
- 2025-09-03 SQL - 通过TSQL代码方式进行简单的数据查询 153
- 2025-09-03 利用VBA+SQL查询Excel工作表数据(分组查询)
- 2025-09-03 这才是数据分析全流程,而不是跑个SQL
- 2025-09-03 见过最惊艳的 SQL 查询语句是什么?揭秘高效查询的奥秘
- 最近发表
-
- count(*)、count1(1)、count(主键)、count(字段) 哪个更快?
- 深入探索 Spring Boot3 中 MyBatis 的 association 标签用法
- js异步操作 Promise fetch API 带来的网络请求变革—仙盟创梦IDE
- HTTP状态码超详细说明_http 状态码有哪些
- 聊聊跨域的原理与解决方法_跨域解决方案及原理
- 告别懵圈!产品新人的接口文档轻松入门指南
- 在Javaweb中实现发送简单邮件_java web发布
- 优化必备基础:Oracle中常见的三种表连接方式
- Oracle常用工具使用 - AWR_oracle工具有哪些
- 搭载USB 3.1接口:msi 微星 发布 990FXA Gaming 游戏主板
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)