mysql中有没有嵌套查询语句


本文小编为大家详细介绍“mysql中有没有嵌套查询语句”,内容详细,步骤清晰,细节处理妥当,希望这篇“mysql中有没有嵌套查询语句”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。 mysql中有嵌套查询语句,语法为“SELECT语句 WHERE 条件(SELECT语句)”;该语句也被称为子查询语句,能够在已有的查询语句中的where后面再嵌套一层查询语句,也即将内层查询结果当做外层查询参照的数据来使用。本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。嵌套查询,也称为子查询,是实际工作中经常用到的一种查询方式。子查询其实就是在已有的查询语句中的where后面再嵌套一层查询语句,也就是把内层查询结果当做外层查询参照的数据表来使用。在工作中,经常会遇见4种子查询,即含有比较运算符(>、>=、
使用含比较运算符的嵌套查询时,需要注意,比较运算符后面的子查询只能返回一个结果。(2)含ANY或ALL关键词的嵌套查询
对于含比较运算符的嵌套查询来说,嵌套部分的查询语句只能返回一个值。那如果子查询返回多个值,就需要用到ANY或者ALL关键词了。通常,ANY / ALL 关键词经常和比较运算符连用,下面是6种比较运算符与ANY / ALL 关键词的搭配结果:
这里的查询逻辑是这样的:首先查询管理系中学生的年龄(去重),得到的结果是22和24;然后查询出非管理系中年龄比22或24年龄小的学生信息(也就是年龄小于24的非管理系学生信息)。
这里的查询逻辑是这样的:首先查询管理系中学生的年龄(去重),得到的结果是22和24;然后查询出非管理系中年龄比22和24都大的学生信息(也就是年龄大于24的非管理系学生信息)。(3)含IN关键词的嵌套查询
当查询条件涉及某些已知的可枚举离散值的时候,我们就可以选择IN关键词来完成数据的提取。IN关键词有两种用法:将可枚举的离散值直接写在值列表中当离散值是基于其他表的筛选结果时,就可以使用嵌套查询,即把另一个表的查询语句块写在IN关键词后面的括号里。需要注意的是,在使用IN关键词的嵌套查询的时候,嵌套部分只能返回一个字段的信息(比如上面的department字段或者id字段),如果返回两个及以上字段信息则会出现语法错误。(4)含EXISTS关键词的嵌套查询
EXISTS 关键词的作用和 IN关键词非常类似,不同的是,通过EXISTS关键词的嵌套查询返回的不是具体的值集合,而是满足条件的逻辑值(也就是True / False)。也就是说,EXISTS的作用就是“判断是否存在满足某种条件的记录”,如果存在这样的记录就返回真(True),如果不存在这样的记录就返回假(False)。需要注意的是,使用EXISTS关键词的嵌套语句 WHERE与EXISTS关键词之间没有任何参数,这是因为EXISTS只需要一个参数,通常是在EXISTS右侧加一个子查询语句。此外,EXISTS后面的子查询中SELECT后面可以写表中任何一个字段或者星号或者一个常数,因为EXISTS后面的子查询只关心是否存在满足条件的记录。下面返回的结果都是一样:【补充】关于IN和EXISTS两个关键词还有两个延伸关键词NOT IN和NOT EXISTS对于IN和EXISTS两个关键词,大多数情况下都可以相互替换,主要差别是使用效率问题,通常情况下采用EXISTS要比IN效率要高,但也要看实际情况具体使用:IN适合于外表大而内表小的情况;EXISTS适合于外表小而内表大的情况。读到这里,这篇“mysql中有没有嵌套查询语句”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过开发云主机域名才能领会,如果想了解更多相关内容的文章,欢迎关注开发云行业资讯频道。

相关推荐: Web常见安全漏洞有哪些

本篇内容主要讲解“Web常见安全漏洞有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Web常见安全漏洞有哪些”吧!1、什么是SQL注入?SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 06/28 12:41
下一篇 06/28 12:41

相关推荐