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

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

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

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

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

MySQL嵌套查询实现子查询的方法_第1张图片

MySQL嵌套查询实现子查询的方法_第2张图片

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

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

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

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

MySQL嵌套查询实现子查询的方法_第3张图片

2.带ALL关键字的子查询

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

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

MySQL嵌套查询实现子查询的方法_第4张图片

3.带EXISTS关键字的子查询

MySQL嵌套查询实现子查询的方法_第5张图片

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

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

MySQL嵌套查询实现子查询的方法_第6张图片

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

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

MySQL嵌套查询实现子查询的方法_第7张图片

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

4.带IN关键字的子查询

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

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

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

MySQL嵌套查询实现子查询的方法_第8张图片

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

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

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

你可能感兴趣的:(MySQL嵌套查询实现子查询的方法)