mysql中有没有嵌套查询语句

72次阅读
没有评论

共计 4154 个字符,预计需要花费 11 分钟才能阅读完成。

本文丸趣 TV 小编为大家详细介绍“mysql 中有没有嵌套查询语句”,内容详细,步骤清晰,细节处理妥当,希望这篇“mysql 中有没有嵌套查询语句”文章能帮助大家解决疑惑,下面跟着丸趣 TV 小编的思路慢慢深入,一起来学习新知识吧。

mysql 中有嵌套查询语句,语法为“SELECT 语句 WHERE 条件 (SELECT 语句)”;该语句也被称为子查询语句,能够在已有的查询语句中的 where 后面再嵌套一层查询语句,也即将内层查询结果当做外层查询参照的数据来使用。

本教程操作环境:windows10 系统、mysql8.0.22 版本、Dell G3 电脑。

mysql 中有嵌套查询语句吗

嵌套查询,也称为子查询,是实际工作中经常用到的一种查询方式。子查询其实就是在已有的查询语句中的 where 后面再嵌套一层查询语句,也就是把内层查询结果当做外层查询参照的数据表来使用。

在工作中,经常会遇见 4 种子查询,即含有比较运算符(、=、、=、=、!=)、IN 关键词、ANY/ALL 关键词以及 EXISTS 关键词的嵌套查询。下面我们以学员考试成绩为例,来学习一下这四种子查询的应用。

#  创建学员信息表  
CREATE TABLE stu_info
id INT AUTO_INCREMENT PRIMARY KEY, 
iname VARCHAR(20), 
gender CHAR(1), 
department VARCHAR(10), 
age TINYINT, 
province VARCHAR(10), 
email VARCHAR(50), 
mobilephone CHAR(11)
#  向学员表中插入数据  
INSERT INTO stu_info(iname,gender,department,age,province,email,mobilephone) VALUES 
(张勇 , 男 , 数学系 ,23, 河南 , sfddf123dd@163.com , 13323564321), 
(王兵 , 男 , 数学系 ,25, 江苏 , lss1993@163.com , 17823774329), 
(刘伟 , 男 , 计算机系 ,21, 江苏 , qawsed112@126.com , 13834892240), 
(张峰 , 男 , 管理系 ,22, 上海 , 102945328@qq.com , 13923654481), 
(董敏 , 女 , 生物系 ,22, 浙江 , 82378339@qq.com , 13428439022), 
(徐晓红 , 女 , 计算机系 ,24, 浙江 , xixiaohong@gmail.com , 13720097528), 
(赵伊美 , 女 , 数学系 ,21, 江苏 , zhaomeimei@163.com , 13417723980), 
(王建国 , 男 , 管理系 ,24, 浙江 , 9213228402@qq.com , 13768329901), 
(刘清 , 女 , 统计系 ,23, 安徽 , lq1128@gmail.com , 17823651180), 
( 赵家和 , 男 , 计算机系 ,28, 山东 , dcrzdbjh@163.com , 13827811311 
#  创建学员成绩表  
CREATE TABLE stu_score( id INT , Excel TINYINT, Tableau TINYINT, MySQL TINYINT ); 
#  向成绩表中插入数据  
INSERT INTO stu_score VALUES 
(1,87,72,88), 
(3,90,66,72), 
(2,90,70,86), 
(4,88,82,76), 
(8,92,67,80), 
(10,88,82,89), 
(5,79,66,60), 
(7,91,78,90), 
(6,82,79,88), 
(9,85,70,85); 
# 1. 查询年龄超过所有学员平均年龄的学员信息  
SELECT * FROM stu_info 
WHERE age  = avg(age); 
#需要注意的是 Where 后面不能使用聚合函数
#应该修改成
SELECT AVG(age) FROM stu_info;
SELECT * FROM stu_info
WHERE age =23.3
#二合一  
# 1. 查询年龄超过所有学员平均年龄的学员信息  
SELECT * FROM stu_info 
WHERE age  = (SELECT AVG(age) FROM stu_info);
# 2. 查询年龄不低于所属系平均年龄的学员信息  
SELECT * FROM stu_info AS s1 
WHERE age = ( SELECT avg(age) FROM stu_info AS s2 
  WHERE s1.department = s2.department);

使用含比较运算符的嵌套查询时,需要注意,比较运算符后面的子查询只能返回一个结果。

(2)含 ANY 或 ALL 关键词的嵌套查询
对于含比较运算符的嵌套查询来说,嵌套部分的查询语句只能返回一个值。那如果子查询返回多个值,就需要用到 ANY 或者 ALL 关键词了。通常,ANY / ALL 关键词经常和比较运算符连用,下面是 6 种比较运算符与 ANY / ALL 关键词的搭配结果:

# 1. 查询非管理系中比管理系任意一个学员年龄小的学员信息  SELECT * FROM stu_info 
WHERE age   ANY(SELECT DISTINCT age FROM stu_info WHERE department =  管理系) 
 AND department !=  管理系 

这里的查询逻辑是这样的:首先查询管理系中学生的年龄(去重),得到的结果是 22 和 24;然后查询出非管理系中年龄比 22 或 24 年龄小的学生信息(也就是年龄小于 24 的非管理系学生信息)。

# 2. 查询非管理系中比管理系所有学员年龄大的学员信息  SELECT * FROM stu_info 
WHERE age   ALL (SELECT DISTINCT age FROM stu_info WHERE department =  管理系) 
 AND department !=  管理系 

这里的查询逻辑是这样的:首先查询管理系中学生的年龄(去重),得到的结果是 22 和 24;然后查询出非管理系中年龄比 22 和 24 都大的学生信息(也就是年龄大于 24 的非管理系学生信息)。

(3)含 IN 关键词的嵌套查询
当查询条件涉及某些已知的可枚举离散值的时候,我们就可以选择 IN 关键词来完成数据的提取。IN 关键词有两种用法:

将可枚举的离散值直接写在值列表中

当离散值是基于其他表的筛选结果时,就可以使用嵌套查询,即把另一个表的查询语句块写在 IN 关键词后面的括号里。

# 1. 查询数学系和计算机系的学员信息  
SELECT * FROM stu_info WHERE department IN( 数学系 , 计算机系  
# 2. 查询与张勇、刘伟同一个系的学员信息  
SELECT * FROM stu_info 
WHERE department IN (SELECT department FROM stu_info WHERE iname IN( 张勇 , 刘伟  
# 3. 查询 MySQL 成绩大于 85 分的学员信息  
SELECT * FROM stu_info 
WHERE id IN (SELECT id FROM stu_score WHERE MySQL   85);

需要注意的是,在使用 IN 关键词的嵌套查询的时候,嵌套部分只能返回一个字段的信息(比如上面的 department 字段或者 id 字段),如果返回两个及以上字段信息则会出现语法错误。

(4)含 EXISTS 关键词的嵌套查询
EXISTS 关键词的作用和 IN 关键词非常类似,不同的是,通过 EXISTS 关键词的嵌套查询返回的不是具体的值集合,而是满足条件的逻辑值(也就是 True / False)。也就是说,EXISTS 的作用就是“判断是否存在满足某种条件的记录”,如果存在这样的记录就返回真(True),如果不存在这样的记录就返回假(False)。

#  查询 MySQL 成绩大于 85 分的学员信息  SELECT * FROM stu_info 
WHERE EXISTS(SELECT * FROM stu_score WHERE stu_score.id = stu_info.id AND MySQL   85);

需要注意的是,使用 EXISTS 关键词的嵌套语句 WHERE 与 EXISTS 关键词之间没有任何参数,这是因为 EXISTS 只需要一个参数,通常是在 EXISTS 右侧加一个子查询语句。此外,EXISTS 后面的子查询中 SELECT 后面可以写表中任何一个字段或者星号或者一个常数,因为 EXISTS 后面的子查询只关心是否存在满足条件的记录。下面返回的结果都是一样:

【补充】关于 IN 和 EXISTS 两个关键词还有两个延伸关键词 NOT IN 和 NOT EXISTS

#  查询数学系和计算机系之外的学员信息  
#  方法一  
SELECT * FROM stu_info 
WHERE department NOT IN( 数学系 , 计算机系  
#方法二  
SELECT * FROM stu_info 
WHERE NOT EXISTS(SELECT * FROM stu_score WHERE department IN( 数学系 , 计算机系) and stu_score.id = stu_info.id); 
# not exists 的逻辑比较复杂,需要大家慢慢领会  
#  主要看 not exists 括号中的 sql 语句是否有结果,无结果:才会继续执行 where 条件;有结果:视为  where 条件不成立。 
#  当子查询和主查询有关联条件时,相当于从主查询中去掉子查询的数据。

对于 IN 和 EXISTS 两个关键词,大多数情况下都可以相互替换,主要差别是使用效率问题,通常情况下采用 EXISTS 要比 IN 效率要高,但也要看实际情况具体使用:IN 适合于外表大而内表小的情况;EXISTS 适合于外表小而内表大的情况。

读到这里,这篇“mysql 中有没有嵌套查询语句”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注丸趣 TV 行业资讯频道。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计4154字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)