SQL语句的MINUS,INTERSECT和UNION ALL的解析


本文摘自PHP中文网,作者一个新手,侵删。

SQL语句中的三个关键字:MINUS(减去),INTERSECT(交集)和UNION ALL(并集);

关于集合的概念,中学都应该学过,就不多说了.这三个关键字主要是对数据库的查询结果进行操作,正如其中文含义一样:两个查询,MINUS是从第一个查询结果减去第二个查询结果,如果有相交部分就减去相交部分;否则和第一个查询结果没有区别. INTERSECT是两个查询结果的交集,UNION ALL是两个查询的并集;

虽然同样的功能可以用简单SQL语句来实现,但是性能差别非常大,有人做过实验:made_order共23万笔记录,charge_detail共17万笔记录:

1

2

3

4

5

6

7

8

9

10

11

12

    SELECT order_id FROM made_order

  MINUS

  SELECT order_id FROM charge_detail

耗时:1.14 sec

  

  SELECT a.order_id FROM made_order a

   WHERE a.order_id NOT exists (

     SELECT order_id

     FROM charge_detail

     WHERE order_id = a.order_id

   )

耗时:18.19 sec

性能相差15.956倍!因此在遇到这种问题的时候,还是用MINUS,INTERSECT和UNION ALL来解决问题,否则面对业务中随处可见的上百万数据量的查询,数据库服务器还不被咱玩的死翘翘?

PS:应用两个集合的相减,相交和相加时,是有严格要求的:1.两个集合的字段必须明确(用*就不行,报错);2.字段类型和顺序相同(名称可以不同),如:集合1的字段1是NUMBER,字段2是VARCHAR,那么集合2的字段1必须也是NUMBER,字段2必须是VARCHAR;3.不能排序,如果要对结果排序,可以在集合运算后,外面再套一个查询,然后排序,如前面的例子可以改成:

1

2

3

4

5

SELECT * FROM

   (SELECT order_id FROM made_order

   MINUS

  SELECT order_id FROM charge_detail)

ORDER BY ORDER_ID ASC

以上就是SQL语句的MINUS,INTERSECT和UNION ALL的解析的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

union all是什么意思

sql语句的minus,INTERSECT和union all的解析

sql union用法是什么?

mysql如何用minus运算符?

mysql中union与union all的用法

使用union和in哪个效率高

更多相关阅读请进入《INTERSECT》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...