MySQL数据查询之子查询


MySQL数据查询之子查询

子查询是指一个查询语句嵌套在另一个查询语句内部的查询。在select子句中先计算子查询,子查询结果作为外层另一个查询的过滤条件,查询可以基于一个表或者多个表。

子查询中常用的操作符有any(some)、all、in、exists。子查询可以添加到select、update和delete语句中,而且可以进行多层嵌套。子查询中也可以使用比较运算符,如"",">=“和”!="。


(1)带any、some关键字的子查询
(2)带all关键字的子查询
(3)带exists关键字的子查询
(4)带in关键字的子查询
(5)带比较运算符的子查询

(免费学习推荐:mysql视频教程


(1)、带any、some关键字的子查询

any和some关键字是同义词,表示满足其中任一条件,允许创建一个表达式对子查询的返回值列表进行比较,只要满足内层子查询中的任何一个比较条件,就返回一个结果作为外层查询的条件。

下面定义两个表tbl1和tbl2,并向两个表中插入数据:

mysql> create table tbl1( num1 int not null);Query OK, 0 rows affected (0.13 sec)mysql> create table tbl2(num2 int not null);Query OK, 0 rows affected (0.10 sec)mysql> insert into tbl1 values(1),(5),(13),(27);Query OK, 4 rows affected (0.05 sec)Records: 4  Duplicates: 0  Warnings: 0mysql> insert into tbl2 values(6),(14),(11),(20);Query OK, 4 rows affected (0.06 sec)Records: 4  Duplicates: 0  Warnings: 0

any关键字接在一个比较操作符后面,表示若与子查询返回的任何职比较为true,则返回true。

【例】返回tbl2表的所有num2列,然后将tbl1中的num1的值与之进行比较,只要大于num2的任何一个值,即为符合条件的结果。

mysql> select num1 from tbl1 where num1 > any(select num2 from tbl2);+------+| num1 |+------+|   13 ||   27 |+------+2 rows in set (0.00 sec)
(2)、带all关键字的子查询
  • all关键字需要同时满足所有内层查询的条件。
  • all关键字接在一个比较操作符后面,表示与子查询返回的所有值比较为true,则返回true。

【例】返回tbl1表中比tbl2表num2列所有值都大的值,SQL语句如下:

mysql> select num1 from tbl1 where num1 > all(select num2 from tbl2);+------+| num1 |+------+|   27 |+------+1 row in set (0.00 sec)
(3)、带exists关键字的子查询
  • exists关键字后面的参数是一个任意的子查询,系统对子查询进行运算以判断它是否返回行,如果至少返回一行,那么exists的结果为true,此时外层查询语句将进行查询;如果子查询没有返回任何行,那么exists返回的结果是false,此时外层语句将不进行查询。

【例1】查询suppliers表中是否存在s_id=107的的供应商,如果存在,则查询fruits表中的记录,SQL语句如下:

mysql> select * from fruits    -> where exists
    -> (select s_name from suppliers where s_id = 107);+------+------+------------+---------+| f_id | s_id | f_name     | f_price |+------+------+------------+---------+| 12   |  104 | lemon      |    6.40 || a1   |  101 | apple      |    5.20 || a2   |  103 | apricot    |    2.20 || b1   |  101 | blackberry |   10.20 || b2   |  104 | berry      |    7.60 || b5   |  107 | xxxx       |    3.60 || bs1  |  102 | orange     |   11.20 || bs2  |  105 | melon      |    8.20 || c0   |  101 | cherry     |    3.20 || m1   |  106 | mango      |   15.70 || m2   |  105 | xbabay     |    2.60 || m3   |  105 | xxtt       |   11.60 || o2   |  103 | coconut    |    9.20 || t1   |  102 | banana     |   10.30 || t2   |  102 | grape      |    5.30 || t4   |  107 | xbabay     |    3.60 |+------+------+------------+---------+16 rows in set (0.00 sec)

由结果可知,内层查询结果表明suppliers表中存在s_id=107的记录,因此exists表达式返回true;外层查询语句接收true之后对表fruits进行查询,返回所有记录。

【例2】查询suppliers表中是否存在s_id=107的供应商,如果存在,则查询fruits表中的f_price大于10.20的记录,SQL语句如下:

mysql> select * from fruits    -> where f_price > 10.20 and exists
    -> (select s_name from suppliers where s_id = 107);+------+------+--------+---------+| f_id | s_id | f_name | f_price |+------+------+--------+---------+| bs1  |  102 | orange |   11.20 || m1   |  106 | mango  |   15.70 || m3   |  105 | xxtt   |   11.60 || t1   |  102 | banana |   10.30 |+------+------+--------+---------+4 rows in set (0.00 sec)

可以看到,内层查询表名suppliers表中存在s_id=107的记录,因此exists表达式返回true;外层查询语句接收true之后根据查询条件f_price>10.20对fruits表进行查询,返回结果为4条f_price大于10.20的记录。

  • not exists与exists使用方法相同,返回的结果相反。子查询如果至少返回一行,那么not exists的结果为false,此时外层查询语句将不进行查询;如果子查询没有返回任何行,那么not exists返回的结果就是true,此时外层语句将进行查询。

【例3】查询suppliers表中是否存在s_id =107的供应商,如果不存在就查询fruits表中的记录,SQL语句如下:

mysql> select * from fruits    -> where not exists
    -> (select s_name from suppliers where s_id = 107);Empty set (0.00 sec)

可以看到,内层查询返回结果为false,外层表达式接收false将不再查询fruits表中的记录。

注意:exists 和 not exists的结果只取决于是否会返回行,而不取决于这些行的内容,所以这个子查询输入列表通常是无关紧要的。

(4)、带in关键字的子查询
  • in关键字进行子查询时,内层查询语句仅仅返回一个数据列,这个数据列里的值将提供给外层查询语句进行比较操作。

【例1】在orderitems表中查询f_id为c0的订单号,并根据订单号查询具有订单号的客户c_id,SQL语句如下:

mysql> select c_id from orders where o_num in
    -> (select o_num from orderitems where f_id = 'c0');+-------+| c_id  |+-------+| 10004 || 10001 |+-------+2 rows in set (0.00 sec)

上面的语句是下面查询方式的简写:

mysql> select o_num from orderitems where f_id = 'c0';+-------+| o_num |+-------+| 30003 || 30005 |+-------+2 rows in set (0.00 sec)mysql> select c_id from orders where o_num in (30003,30005);+-------+| c_id  |+-------+| 10004 || 10001 |+-------+2 rows in set (0.00 sec)

下面介绍与in相反的not in关键字:

【例2】与例1类似,但select语句中使用not in 关键字。SQL语句如下:

mysql> select c_id from orders where o_num not in
    -> (select o_num from orderitems where f_id ='c0');+-------+| c_id  |+-------+| 10001 || 10003 || 10005 |+-------+3 rows in set (0.00 sec)

可以看到返回了三个表,查看orders中的记录可知,c_id等于10001的客户的订单不止一个:

mysql> select * from orders;+-------+---------------------+-------+| o_num | o_date              | c_id  |+-------+---------------------+-------+| 30001 | 2008-09-01 00:00:00 | 10001 || 30002 | 2008-09-12 00:00:00 | 10003 || 30003 | 2008-09-30 00:00:00 | 10004 || 30004 | 2008-10-03 00:00:00 | 10005 || 30005 | 2008-10-08 00:00:00 | 10001 |+-------+---------------------+-------+5 rows in set (0.00 sec)

结果只是排除了订单号,但仍然有可能选择同一个客户。

子查询的功能也可以通过连接查询完成,但子查询使得MySQL代码更容易阅读和编写。

(5)、带比较运算符的子查询

【例1】在suppliers表中查询s_city等于"Tianjin"的供应商s_id,然后在fruits表中查询所有该供应商提供的水果的种类,SQL语句如下:

mysql> select s_id,f_name from fruits    -> where s_id =
    -> (select s1.s_id from suppliers as s1 where s1.s_city = 'Tianjin');+------+------------+| s_id | f_name     |+------+------------+|  101 | apple      ||  101 | blackberry ||  101 | cherry     |+------+------------+3 rows in set (0.00 sec)

【例2】在suppliers表中查询s_city等于"Tianjin"的供应商,s_id,然后在fruits表中查询所有非该供应商提供的水果的种类,SQL语句如下:

mysql> select s_id , f_name from fruits    -> where s_id <>
    -> (select s1.s_id from suppliers as s1 where s1.s_city ='Tianjin');+------+---------+| s_id | f_name  |+------+---------+|  104 | lemon   ||  103 | apricot ||  104 | berry   ||  107 | xxxx    ||  102 | orange  ||  105 | melon   ||  106 | mango   ||  105 | xbabay  ||  105 | xxtt    ||  103 | coconut ||  102 | banana  ||  102 | grape   ||  107 | xbabay  |+------+---------+13 rows in set (0.00 sec)
更多相关免费学习推荐:mysql教程(视频)

以上就是MySQL数据查询之子查询的详细内容,更多请关注其它相关文章!


# 与子  # 网站建设行业新闻  # 通过病毒式营销进行app推广  # 上蔡网站推广团队电话  # 专业的网站建设服务好吗  # 舟山网站优化公司报价  # 西安企业网站建设宣传  # 鼓楼网络营销推广业务  # seo定价  # 郴州网站建设方案报价表  # 梅县全媒体营销推广中心  # MySQL  # 查询结果  # 将不  # 任何一个  # 数据查询  # 是否存在  # 可以看到  # 之子  # 运算符  # 镜像  # 子查询 


相关栏目: 【 Google疑问12 】 【 Facebook疑问10 】 【 优化推广96088 】 【 技术知识133117 】 【 IDC资讯59369 】 【 网络运营7196 】 【 IT资讯61894


相关推荐: PPT智能排版生成入口 免费PPT内容自动生成平台  C++ static关键字作用_C++静态成员变量与静态函数  Eclipse开发J*a快速入门  猫眼电影app怎么查询电影院的营业时间_猫眼电影影院营业时间查询教程  网站体验不好=浪费钱:如何提升-用户体验效果差  mysql如何配置从库只读_mysql从库只读设置方法  Go语言反射机制:如何访问被嵌入结构体遮蔽的方法  iPhone16Plus参数配置如何调整声音_iPhone16Plus参数配置声音调整详细方法  Golang如何实现HTTP请求重试机制_Golang HTTP请求错误处理策略  VS Code快捷键when上下文子句的妙用  谷歌浏览器如何查找和删除恶意软件 谷歌浏览器内置安全清理工具使用教程  c++如何掌握指针的核心用法_c++指针入门到精通指南  感染了幽门螺杆菌一定会导致胃癌吗?蚂蚁庄园今日答案最新11.30  如何在CSS中使用伪类选择器_hover实现悬停效果  tiktok国际版入口_tiktok官网网页版链接  C++中的explicit关键字有什么作用_C++类型转换控制与explicit使用  Python项目中的条件导入:解决跨模块依赖问题  《海贝音乐》均衡器设置方法  抖音赚钱快速入门_新手必看的抖音赚钱步骤  实时数据流中高效查找最小值与最大值  《雷电模拟器》自动点击设置方法  123平台官方登录入口 123邮箱网页端在线沟通工具  《金山词霸》语音翻译方法  荣耀magicv5怎么上手测评  Python测试中模块导入路径解析的最佳实践  J*aScript类型数组_TypedArray使用  Golang中的rune与byte类型区别是什么_Golang字符与字节处理详解  Retrofit根路径POST请求:@POST("/") 的应用与解析  百度地图离线地图无法加载如何解决 百度地图离线地图加载优化方法  Dagster资产间数据传递与用户配置管理教程  PHP动态导航按钮:根据用户登录状态切换链接与文本  申通快递查询 申通物流快递单实时查询入口  LocoySpider如何批量采集电商商品_LocoySpider电商采集的模板应用  Cassandra中复合主键、二级索引与ORDER BY排序的限制与解决方案  圆通快递官方入口不需要登录 在线查询入口快速查询  手机远程连接电脑方法  米侠浏览器插件无法启用怎么办 米侠浏览器扩展兼容性修复  win11关机几秒又自己开机 Win11关机自动重启问题修复  暴风影音官网正式版_暴风影音手机版官网下载安卓  Win10截图远程协助 Win10远程桌面截屏法【场景应用】  《腾讯相册管家》注销账号方法  TikTok视频播放中断怎么办 TikTok播放异常修复方法  Animex动漫社正版在线入口 Animex动漫社动漫官方观看网  Win10共享文件夹设置方法 Win10局域网文件共享全攻略【教程】  Win10关闭UAC用户账户控制的方法 Win10降低安全提示等级【技巧】  优化 React onClick 事件处理:函数引用与箭头函数的对比  J*a里如何处理ArithmeticException并防止除零_算术异常防护策略解析  Lar*el怎么实现全文搜索_Lar*el Scout集成Algolia教程  有道AI翻译入口 智能写作官方网站入口  六级准考证号怎么查_四六级准考证查询入口官网 

 2021-03-16

了解您产品搜索量及市场趋势,制定营销计划

同行竞争及网站分析保障您的广告效果

点击免费数据支持

提交您的需求,1小时内享受我们的专业解答。

运城市盐湖区信雨科技有限公司


运城市盐湖区信雨科技有限公司

运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。

 8156699

 13765294890

 8156699@qq.com

Notice

We and selected third parties use cookies or similar technologies for technical purposes and, with your consent, for other purposes as specified in the cookie policy.
You can consent to the use of such technologies by closing this notice, by interacting with any link or button outside of this notice or by continuing to browse otherwise.