MYSQL子查询的五种形式

php中文网
发布: 2016-06-07 15:21:08
原创
1635人浏览过

mysql从4.1版开始支持子查询功能,在此版本前,可以用join写连表查询来进行替代,但不推荐这么写,相当的麻烦。mysql子查询的几种常见写法: select * from xxx where col=[ any | all ]( select * from xxxx); 该句法可分为加关键词和不加关键词的写法,当

mysql从4.1版开始支持子查询功能,在此版本前,可以用join写连表查询来进行替代,但不推荐这么写,相当的麻烦。mysql子查询的几种常见写法:

<ol><li><span><span>select</span><span> * </span><span>from</span><span> xxx </span><span>where</span><span> col = [</span><span>any</span><span>|</span><span>all</span><span>](</span><span>select</span><span> * </span><span>from</span><span> xxxx); </span></span></li></ol>
登录后复制

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

<ol><li><span><span>select</span><span> * </span><span>from</span><span> xxx </span><span>where</span><span> col </span><span>in</span><span> (</span><span>select</span><span> * </span><span>from</span><span> xxxx); </span></span></li></ol>
登录后复制

该 句法相当的明了,就是查询语句的where子句是以子查询语句的结果作为其范围的,与上一种语法的any相似。

<ol><li><span><span>select</span><span> row(value1,value2.....) = [</span><span>any</span><span>](selectcol1,col2..); </span></span></li></ol>
登录后复制

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

<ol><li><span><span>select</span><span>  .... </span><span>where</span><span> col = [</span><span>not</span><span>] exists (</span><span>select</span><span>......); </span></span></li></ol>
登录后复制

该语句比较蹩脚,其执行是这样的:当子查询进行操作,有返回结果的时候,该语句才会执行,而且有多少个结果,语句就执行几次。

<ol><li><span><span>select</span><span> .... </span><span>from</span><span> (</span><span>select</span><span> .....) </span><span>as</span><span> </span><span>name</span><span> </span><span>where</span><span> ...... </span></span></li></ol>
登录后复制

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

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

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号