mysql子查询的五种方式


mysql从4.1版开始支持子查询功能,下面树懒君带来mysql子查询的几种常见写法:

select * from xxx where col = [any|all](select * from xxxx); 

该句法可分为加关键词和不加关键词的写法。

当不加关键词的时候,子查询语句返回的是一个离散值(注意是一个),查询语句将以子查询语句的结果作为自己 where子句的条件进行查询。

any则表示,查询语句是以子查询返回的值作为一个范围,在此值范围内进行查询,与in关键字相像。

 select * from xxx where col in (select * from xxxx); 

查询语句的where子句是以子查询语句的结果作为其范围的。

select row(value1,value2.....) = [any](selectcol1,col2..); 

子查询语句的执行所得的结果与查询的结果集匹配,若能找到匹配的返回真,否则返回假,并且两边的结果集都是一组离散值。

select  .... where col = [not] exists (select......); 

当子查询进行操作,有返回结果的时候,该语句才会执行,而且有多少个结果,语句就执行几次。

select .... from (select .....) as name where ...... 

通过子查询执行的结果来构造一张新的表,其用来作为主句的查询的对象,该句法功能非常强大,在一些复杂的查询中会经常用到。

子查询虽然挺方便,但其有不少缺点,其不支持limit,而且经实验证明其执行效率相当不理想,在一般的情况下,还是不推荐是用子查询。


评论区(0)

评论