SQL语句的MINUS,INTERSECT和UNION ALL

 

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

 

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

 

 虽然一样的功能能够用简单SQL语句来实现,可是性能差异很是大,有人作过实验:made_order共23万笔记录,charge_detail共17万笔记录:性能

    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来解决问题,不然面对业务中随处可见的上百万数据量的查询,数据库服务器还不被咱玩的死翘翘?spa

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

SELECT * FROM
   (SELECT order_id FROM made_order
   MINUS
  SELECT order_id FROM charge_detail)
ORDER BY ORDER_ID ASC排序