SQL Sever 子查询与嵌套查询

简介: 作者主页:https://www.couragesteak.com/

数据库表

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

1.带 in 的嵌套查询

查询Student表 并且 Sno 在 SC表中有

select * from Student where Sno in(select Sno from SC)

在这里插入图片描述

2.带 not in 的嵌套查询

查询学生表中 Sno在SC表不存在的学生

select * from Student 
where Sno not in
(select Sno from SC)

伪代码

查询学生表
学生表中的Sno
不在SC表中

在这里插入图片描述

3.带 some 的嵌套查询

SQL支持3中定量比较谓词:some、any 和 all。他们都是判断是否任何或全部返回值都满足搜索要求的。其中,some和any谓词是存在量的,只注重是否有返回值满足搜索要求。这两谓词含义相同,可以替换使用。

查询学生表中,年龄小于平均值的学生

select * from Student 
where Sage < some 
(select avg(Sage) from Student)

伪代码

查询学生表
年龄小于
(查询 学生表 年龄平均值)

在这里插入图片描述

4. 带 all 的嵌套查询

all 谓词的使用方法和 any 或者 some 谓词一样,也是把列值与子查询结果进行比较,但是它不要求任意结果值得列值为真,而是要求所有列的查询结果都为真,否则就不返回行。

查询课程表 并且成绩 没有 有 成绩超过 90分的课程

select * from Course
where Cno <> all
(select Cno from SC where grade > 90)

伪代码

查询课程表
不存在的课程号在
(查询有分数>90分的课程号)

在这里插入图片描述

5. 带exists的嵌套查询

exists谓词只注重子查询结果是否返回行。如果子查询返回一个或多个行,谓词返回为真值,否则为假。
exists搜索条件并不真正使用子查询的结果。他仅测试子查询是否产生任何结果。

查询没有参加考试的学生

select * from Student
where not exists
(select Sno from SC where Student.Sno = SC.Sno)

伪代码

查询学生表
不存在
(查询 Student.Sno = SC.Sno的结果)
相关文章
|
10天前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
22天前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
75 10
|
15天前
|
SQL 关系型数据库 MySQL
|
29天前
|
SQL 数据库 开发者
功能发布-自定义SQL查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。
|
25天前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
31 0
|
SQL 数据库 数据安全/隐私保护
【SQL Sever】安装过程
下载了sql sever,如下: 首先把iso解压,如下: 1.点击   2.打开页面后   3. 接下来直接下一步下一步     完成之后,需要重启计算机才能使用! 4. 重启之后,进入配置工具   将所有的端口号更改为1433 、 更改完成之后,进入SQL Sever服务,找到 将其设置为自动并且启动!   5.初次启动,更改sa用户的密码     咱们第一次登陆的选择Windows身份验证 一个点  代表本机 Windows身份认证就是操作系统的身份。
983 0
|
2月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
4月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
115 13
|
4月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
下一篇
无影云桌面