MySQL嵌套查询实现子查询的方法

吾爱主题 阅读:148 2024-04-01 23:23:22 评论:0

一个查询语句嵌套在另一个查询语句内部的查询

常用操作符:ANY(SOME), ALL, IN, EXISTS

比较运算符:>, >=, <, <=, != 等

创建两个表,表明分别是tb1,tb2,并向其各插入了数据。

 

1.带ANY(SOME)关键字的子查询

这里any和some是同义词,都是表示满足任一条件。

例:查询tb1中的所有数据,只要大于tb2表中数据的任意值,既符合查询条件。

select num1 from tb1 where num1>ANY(select num2 from tb2);

 

2.带ALL关键字的子查询

例:查询tb1中的所有数据,返回其中比tb2表中任何值都大的数据。

select num1 from tb1 where num1>ALL(select num2 from tb2);

 

3.带EXISTS关键字的子查询

例1:查询fruits表中name字段下是否有apple,若有则查询fruits表中的记录,否则不查询。

select * from fruits where EXISTS(select name from fruits where name="apple");

例2:查询tb1表中是否存在num1=13的记录,若存在,则查询fruits表中price大于6.00的记录。

select * from fruits where price>6.00 and EXISTS (select num1 from tb1 where num1=13);

相反,可以使用 not exists 查询不存在的,用法相同。

 

4.带IN关键字的子查询

表示查询结果在后面子查询的范围之中

例如:查询tb1表中的num1字段下的数据作为数据列,fruits表中id字段下的数据与其进行比较,返回符合条件的记录。

select * from fruits where id IN (select num1 from tb1);

 

5.带比较运算符的子查询

select * from 表名 where 字段名 > (select ······);

到此这篇关于MySQL嵌套查询实现子查询的方法的文章就介绍到这了,更多相关MySQL 子查询内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_39588003/article/details/90084255

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容