子查询一般分为几种

2023年 4月 15日 36.4k 0

一、mysql子查询基本知识 子查询就是在原有的查询语句中,嵌入新的查询,来得到我们想要的结果集。 子查询一般分为:where型子查询、from型子查询和exists型子查询。 1. where 型子查询:

一、mysql子查询基本知识

子查询就是在原有的查询语句中,嵌入新的查询,来得到我们想要的结果集。

子查询一般分为:where型子查询、from型子查询和exists型子查询。

1.where型子查询:将内层查询结果当做外层查询的比较条件。

select 列1,列2,...,列n from 表名 where 列i =/in (select 列1,列2,...,列n from 表名 where ...);

2.from型子查询:把内层的查询结果当成临时表,供外层sql再次查询。查询结果集可以当成表看待。临时表要使用一个别名。

select 列1,列2,...,列n from (select 列1,列2,...,列n from 表名 where ...) as 表别名 where ....;

3.exists型子查询:把外层sql的结果,拿到内层sql去测试,如果内层的sql成立,则该行取出。内层查询是exists后的查询。

select 列1,列2,...,列n from 表名 where exists (select 列1,列2,...,列n from 表名 where ...);

二、查询实例

下图为成绩表和班级表数据。

b6c063eab080441574f5d878fcfe2c1.png

1.查询成绩表中数学成绩最高的学生信息;

0a9b61bea156f207b1370a14497ce5d.png

2.查询成绩表中各个班级的最高总成绩;

69501455f6345420808e6b3f9fa95b7.png

3.根据成绩表和班级表,找出成绩表中缺失成绩的班级;

1c0193ab9496d10138521d2cb3897e2.png

推荐教程: 《sql教程》

以上就是子查询一般分为几种的详细内容,更多请关注每日运维其它相关文章!

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论