• 零基础自学SQL课程 | 子查询


    大家好,我是宁一。

    今天讲解SQL教程第18课:子查询。

    SQL语句可以嵌套,最常见的就是查询语句的嵌套。

    基本语法:

    1. SELECT <字段名>
    2. FROM <表名>
    3. WHERE(
    4. SELECT <字段名>
    5. FROM <表名>
    6. );

    我们一般称外面嵌套的语句为主查询,里面被嵌套的语句为子查询,有时也会叫外查询、内查询,大家知道意思就好。

    子查询要用括号括起来。子查询不仅可以放在WHERE的后面,还可以放在SELECT、FROM的后面,我们一个个来讲解。

    1、子查询+WHERE子句

    SQL执行时,会先执行括号内的子查询,子查询最常与WHERE子句结合使用。子查询的结果作为WHERE子句的筛选条件,完成更复杂的数据检索。

    实例:在Students表中,找出所有在"宁一"后面出生的学生。

    实例解析:需要先确定"宁一"的生日,再将生日作为WHERE筛选条件,得到最终数据。

    第一步:找到"宁一"的生日

    1. SELECT Sage
    2. FROM Students
    3. WHERE Sname = "宁一"

    第二步:将生日作为WHERE筛选条件,得到最终数据,子查询语句要用括号括起来。

    1. SELECT *
    2. FROM Students
    3. WHERE Sage > (
    4. SELECT Sage
    5. FROM Students
    6. WHERE Sname = "宁一"
    7. )

    2、子查询 + SELECT 语句

    子查询还可以与 SELECT 语句结合使用,子查询返回的结果,会作为列显示在结果集中。

    SELECT语句的子查询经常与聚合函数结合使用。因为我们使用聚合函数的时候,记录会合成一条,其它数据细节就不能显示了。

    比如:我们想要查看学生表中所有的学生姓名、学生生日、学生的最大生日。

    示例结果:

    错误写法:

    1. SELECT Sname,Sage,Max(Sage)
    2. FROM Students

    像上面这样写是会报错的,因为聚合函数与其他表中的列(Sname,Sage),同时放在SELECT的后面。需要用GROUP BY语句将这些表中的列(Sname,Sage)分组。

    上面的语句后面加上 GROUP BY Sname,Sage 就可以了。

    但是这样写,会将每组的数据聚合成1条数据,比如每组有3条数据,使用聚合函数MAX()+GROUP BY,最终每组只会显示1条最大值的数据。

    我们需要展现Students表中所有的学生,这样写不能满足我们的需求。

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

    1. SELECT
    2. Sname,
    3. Sage,
    4. (SELECT Max(Sage) FROM Students) AS Maxage
    5. FROM Students

    3、子查询+FROM子句

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

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

    1. SELECT
    2. Sid,
    3. 'student' AS status
    4. FROM Students
    5. WHERE Sid <= 5

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

    1. SELECT Sid,status
    2. FROM (
    3. SELECT
    4. Sid,
    5. 'student' AS status
    6. FROM Students
    7. WHERE Sid <= 5
    8. ) AS s -- 必须加别名
    9. WHERE Sid > 2

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

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

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

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

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

    1. SELECT *
    2. FROM Teachers
    3. WHERE Tid IN (
    4. SELECT
    5. DISTINCT Tid
    6. FROM Students
    7. )

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

  • 相关阅读:
    一级必杀,防不胜防的漏洞,WEB安全基础入门—文件上传漏洞
    提升机器视觉与机器学习软件安全性的实践策略
    Json字符串内容比较-超实用版
    “互联网寒冬”来袭,软件测试人员该如何度过这次危机?
    搭建vue2 工程
    ethercat EOE arp
    【springboot】自定义starter(学习笔记)
    Flutter macOS开发教程之 界面布局与UI组件源码(教程含源码)
    MCU的环形FIFO
    东方通登录提示用户不存在或忘记密码的解决方案
  • 原文地址:https://blog.csdn.net/shine_a/article/details/125410265