MySQL子查询有哪五种形式?
2018-06-17 23:54:26来源:未知 阅读 ()
MySQL是一个关系型数据库管理系统,由瑞典MySQLAB公司开发,目前属于Oracle旗下产品。MySQL是最流行的关系型数据库管理系统之一,在web应用方面,MySQL是最好的RDBMS(RelationalDatabaseManagementSystem,关系数据库管理系统)应用软件。
mysql从4.1版开始支持子查询功能,在此版本前,可以用join写连表查询来进行替代,但不推荐这么写,相当的麻烦。以下是mysql子查询的几种常见写法:
1.select*fromxxxwherecol=[any|all](select*fromxxxx);
该句法可分为加关键词和不加关键词的写法,
当不加关键词的时候,
子查询语句返回的是一个离散值
(注意是一个),查询语句将以子查询语句的结果作为自己where子句的条件进行查询,该句法可以在子查询语前加入any、all、exists等关键字,此时子查询语句返回的是一组离散值。any则表示,查询
语句是以子查询返回的值作为一个范围,在此值范围内进行查询,其与in关键字相像;all关键不太好了解,表示起全部匹配啥的。
2.select*fromxxxwherecolin(select*fromxxxx);
该句法相当的明了,就是查询语句的where子句是以子查询语句的结果作为其范围的,与上一种语法的any相似。
3.selectrow(value1,value2.....)=[any](selectcol1,col2..);
该语句的执行实质是:
子查询语句的执行所得的结果与查询的结果集匹配,
若能找到匹配的返回真,否则返回假,并且两边的结果集都是一组离散值。
4.select....wherecol=[not]exists(select......);
该语句比较蹩脚,其执行是这样的:当子查询进行操作,有返回结果的时候,该语句才会执行,
而且有多少个结果,语句就执行几次。
5.select....from(select.....)asnamewhere......
该句法,在平时用的比较少,而且并不好理解。其实是这么一回事,通过子查询执行的结果来构
造一张新的表(这个表是一张衍生数据表,是一张虚拟的表),其用来作为主句的查询的对象,
该句法功能非常强大,在一些复杂的查询中会经常用到。
小编结语:
子查询虽然挺方便,但其有不少缺点,其不支持limit,而且经实验证明其执行效率相当不理想,在一般的情况下,还是不推荐是用子查询。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- MySQL replace函数怎么替换字符串语句 2020-03-09
- PHP访问MySQL查询超时怎么办 2020-03-09
- mysql登录时闪退 2020-02-27
- MySQL出现1067错误号 2020-02-27
- mysql7.x如何单独安装mysql 2020-02-27
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash