加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql必读MySQL子查询的几种常见形式介绍

发布时间:2020-12-12 03:04:56 所属栏目:MySql教程 来源:网络整理
导读:《Mysql必读MySQL子查询的几种常见形式介绍》要点: 本文介绍了Mysql必读MySQL子查询的几种常见形式介绍,希望对您有用。如果有疑问,可以联系我们。 mysql子查询的几种常见写法: MYSQL数据库 代码如下: select * from xxx where col = [any|all](select *

《Mysql必读MySQL子查询的几种常见形式介绍》要点:
本文介绍了Mysql必读MySQL子查询的几种常见形式介绍,希望对您有用。如果有疑问,可以联系我们。

mysql子查询的几种常见写法:
MYSQL数据库

代码如下:
select * from xxx where col = [any|all](select * from xxxx);??

该句法可分为加关键词和不加关键词的写法,当不加关键词的时候,子查询语句返回的是一个离散值(注意是一个),查询语句将以子查询语句的结果作为自己 where子句的条件进行查询,该句法可以在子查询语句前加入any、all、some等关键字,此时子查询语句返回的是一组离散值.any则表示,查询语句是以子查询返回的值作为一个范围,在此值范围内进行查询,其与in关键字相像;all关键不太好了解,表示起全部匹配啥的.
代码如下:
select * from xxx where col in (select * from xxxx);

该 句法相当的明了,就是查询语句的where子句是以子查询语句的结果作为其范围的,与上一种语法的any相似;
代码如下:
select row(value1,value2.....) = [any](selectcol1,col2..);

该语句的执行实质是:子查询语句的执行所得的结果与查询的结果集匹配,若能找到匹配的返回真,否则返回假,并且两边的结果集都是一组离散值;
代码如下:
select??.... where col = [not] exists (select......);

该语句比较蹩脚,其执行是这样的:当子查询进行操作,有返回结果的时候,该语句才会执行,而且有多少个结果,语句就执行几次;
代码如下:
select .... from (select .....) as name where ......

该句法,在平时用的比较少,而且并不好理解.其实是这么一回事,通过子查询执行的结果来构造一张新的表(这个表是一张衍生数据表,是一张虚拟的表),其用来作为主句的查询的对象,该句法功能非常强大,在一些复杂的查询中会经常用到.

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

《Mysql必读MySQL子查询的几种常见形式介绍》是否对您有启发,欢迎查看更多与《Mysql必读MySQL子查询的几种常见形式介绍》相关教程,学精学透。编程之家PHP学院为您提供精彩教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读