大家好,我是宁一。

今天讲解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 SageFROM StudentsWHERE 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表中所有的学生,这样写不能满足我们的需求。

正确写法:结合子查询来实现。

SELECTSname,Sage,(SELECT Max(Sage) FROM Students) AS Maxage
FROM Students

3、子查询+FROM子句

子查询与FROM子句结合使用,子查询结果被当成了一个“表”,可以用SELECT语句做进一步的筛查。

比如:我们先写一个SELECT查询语句

SELECTSid,'student' AS status
FROM Students
WHERE Sid <= 5

将上面的查询语句放在FROM的后面,则上面查询到的结果,就会被当成一个“表”。

SELECT Sid,status
FROM (SELECTSid,'student' AS statusFROM StudentsWHERE Sid <= 5
) AS s -- 必须加别名
WHERE Sid > 2

这里有一个特别要注意的地方,放在FROM后面的子查询,必须要加别名。

复杂的子查询再嵌套进 FROM 里会让整个查询看起来过于复杂,我们一般会将子查询结果储存为视图,然后再直接使用视图作为来源表,视图会SQL高阶课程中详细讲解。

其实子查询就是查询语句嵌套,没有什么新的东西,只是多了一个层级,由内向外地一层层梳理就会很清楚了。

作业:结合Students表,从Teachers表中找出当班主任的老师(通过子查询实现)。

作业解析:先从Students表中,找出所有班主任的Tid并去重,将查询结果作为筛选条件,放在WHERE语句中。

SELECT *
FROM Teachers
WHERE Tid IN (SELECTDISTINCT TidFROM Students
)

点击关注,更新课程第一时间通知哦~

零基础自学SQL课程 | 子查询相关推荐

  1. 零基础自学SQL课程 | DELETE 删除语句

    大家好,我是宁一. 今天是SQL课程的第十课. 讲讲DELETE 删除语句,用来删除表中的一条或多条记录. 基本语法: DELETE FROM <表名> WHERE <筛选条件> ...

  2. ORDER BY 排序子句 | 零基础自学SQL课程系列Day6

    大家好,我是宁一. 今天是SQL教程的第六课,来看看ORDER BY 排序子句. ORDER BY语句是用来排序的,后面跟的是字段名. 基本语法: SELECT <字段名> FROM &l ...

  3. 零基础自学SQL课程 | OUTER JOIN外连接

    大家好,我是宁一. 今天讲解SQL教程第12课:OUTER JOIN外连接. 外连接是左外连接(LEFT OUTER JOIN).右外连接(RIGHT OUTER JOIN).全外连接(FULL OU ...

  4. WHERE条件子句 | 零基础自学SQL课程系列Day5

    大家好,我是宁一. 今天是SQL教程的第五课:来看看WHERE条件子句的用法. WHERE子句基本语法: SELECT <字段名> FROM <表名> WHERE <筛选 ...

  5. INSERT 插入语句 零基础自学SQL课程系列Day8

    大家好,我是宁一. 今天是SQL教程的第八课. 这节课讲讲 INSERT插入语句,用来像数据库中添加数据. 基本语法: INSERT INTO <表名> (列名)VALUES (值); 1 ...

  6. 零基础自学SQL课程 | SQL基本函数大全

    大家好,我是宁一. 今天是我们的第20课:SQL基本函数. MySQL中内置了很多函数,用来处理数值.字符串.日期等,这节课我们来讲讲有哪些常用的函数. 1.数值函数 -- ROUND(数值,保留小数 ...

  7. 零基础自学SQL课程 | IF函数

    大家好,我是宁一. 今天是我们的第22课:IF函数. 大家如果学过其他编程语言,应该对IF函数很熟悉了.用来根据条件,返回不同值. 基本语法: IF(条件表达式, 值1, 值2) 如果条件表达式为Tr ...

  8. t - sql的阶梯:超越基础水平2:写子查询

    t - sql的阶梯:超越基础水平2:写子查询 原文链接:http://www.sqlservercentral.com/articles/Stairway+Series/104517/ 通过格雷戈里 ...

  9. 大数据自学要多久?为什么零基础自学大数据那么久?

    伴随着大数据时代的冲击,大数据开发相关的技术人才成为目前招聘市场炙手可热的高薪岗位,越来越多想要通过技术获得高薪工作的同学选择大数据技术方向.我们知道目前学习大数据可以通过自学或者参加培训两种方式,参 ...

最新文章

  1. ubuntu搭建svn、git遇到的问题及解决办法
  2. SVN版本管理系统的安装 CentOS + Subversion + Apache + Jsvnadmin
  3. 西门子plm_西门子的Teamcenter、TIA Portal、NX MCD是如何结合在一起的
  4. .NET Core 3.0 中的数据库驱动框架 System.Data
  5. 在webstorm中配置sass的自动编译,并且可以指定编译后的css的目录.
  6. 小微型库(1.获取元素的API)
  7. idea 拉取gitee代码_手把手撸一个 IDEA 插件
  8. Qt总结:QMessageBox(原生态弹出框及究极超nice封装自定义弹出框)
  9. jsp隐式对象_JSP隐式对象
  10. springBoot集成Mybatis-Generator
  11. MATLAB中的imagesc
  12. 向英雄联盟生涯致敬,三十行Python代码爬取LOL官网英雄皮肤图片
  13. [2018.10.20 T1] 蛋糕
  14. STC12C5A60S2
  15. YouTube embed gives “restricted from playback on certain sites” error despite API metadata indicatin
  16. 【历史上的今天】12 月 25 日:第一个网络服务器诞生;黑客社区的创始人出生;牛顿诞生
  17. 电脑使用者的眼睛保护
  18. 手机发出的邮件可以撤回吗?已发出的邮件撤回后对方能看到吗?
  19. 什么牌子的护眼灯最好?分享四款护眼灯合格的品牌
  20. 概率论的学习和整理13--方差和协方差(未完成)

热门文章

  1. Win7下如何在windows资源管理器中打开FTP
  2. 14Cr1MoR容器、14Cr1MoR对应材质SA387Gr11CL2
  3. 这是一页纸商业计划书 (Business Plan) 模板(转)
  4. poi---Excel导入数据-ClassNotFoundException
  5. 企业如何实现OA办公系统的最大化应用价值?
  6. 你的网站为什么被黑?
  7. eNSP—静态路由+NAT网络地址转换
  8. 【OpenCV】Mat的使用方法以及Mat中的参数和函数
  9. 【多元统计分析】12.逐步回归
  10. 基于android的计步器文档,基于Android的计步器(Pedometer)的讲解(六)