相关文章推荐
旅途中的茄子  ·  更新SQL子查询 - ·  5 天前    · 
大力的松鼠  ·  Mysql比较日期和时间 - ·  5 天前    · 
严肃的跑步鞋  ·  error: '#' is not ...·  3 月前    · 
温文尔雅的绿茶  ·  Python-docx ...·  5 月前    · 
有爱心的杯子  ·  SQL ...·  1 年前    · 

SQL子查询简介

SQL子查询是指以一个select查询的结果作为另一个select查询的条件来进行查询。结果作为其他select查询条件的select查询称为SQL子查询。注意,SQL子查询不仅仅可以作为其他select查询的条件,还可以作为insert插入和delete删除的条件。SQL子查询常常用于比较复杂的查询操作中,且要查询的条件和字段通常不在一个表内。例如:查询成绩低于60的学生的名字,如果学生的成绩和名字不在一个表内,就可以使用SQL子查询。SQL子查询根据查询的结果,可以分为SQL单行子查询和多行子查询。所谓单行子查询,就是指子查询的结果只有一个,所谓多行子查询,就是指子查询的结果可以有多个。

SQL单行子查询

SQL子查询语法结构很简单,只需要把子查询的SQL语句用括号括起来,并且作为其他查询语句的条件即可,例如:student表存储了学生的基本信息,grade表存储了学生的成绩信息,student表中的id和现在要查询成绩低于60的学生的名字,可以执行以下SQL语句:

select name from student where id =( select Sid from grade where score < 60 );

执行结果如下:

SQL多行子查询 其实,这种查询方式是单行子查询,一旦返回结果多与一行,就会查询失败,如下所示:

那么如果我们想查询大于60分的学生该怎样查询呢?这就需要用到多行子查询,多行子查询其实就是在单行子查询的基础上,添加了一些关键字,比如all、any和in。all表示和所有的查询结果相比,any表示和查询结果的任意一个相比,in表示等于列表中的任何一个。比如,在上例中,要查询大于60分的学生,就应该使用any,SQL语句示例如下:

select name from student where id = any ( select Sid from grade where score > 60 ); select name from student where id in ( select Sid from grade where score > 60 );

查询结果如 下:

其实,in和any的区别在于是否有比较运算符。in不需要使用比较运算符,而any需要使用比较运算符。

至于all,也需要使用比较运算符,all使用的结果与子查询的查询个数和比较运算符相关,规则如下:

如果子查询结果有多个不同的结果,则匹配结果为空;如果查询结果有多个结果,但是这些结果都相同,则匹配该结果。

表示要匹配小于子查询结果最小值。

表示要匹配大于子查询结果最大值。

4.不等于

表示要匹配子查询结果中没有的。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/weixin_40228200/article/details/121947380

职业规划解决方案

开启职业新征程

职业规划帮你掌握人生航向

了解自己的优势,找到适合自己的岗位!

人生不只有一条路,

职业规划帮你发现更多可能性!

赶快来了解一下吧

👇👇👇

即可抢占名额

仅需9.9元

让爱数据助力你的职场生涯

“躺平”不是最好的状态,为什么你要悄悄惊艳所有人?

数据分析薪资如何?23年前景如何?

Excel技巧大揭秘:5个令你进阶的必备玩法!

7个统计学必知的概念!数据分析师必备

精选合集:

招聘精选合集

数据分析必看 返回搜狐,查看更多

责任编辑: