SQL语句中的三个关键字:MINUS(减去),INTERSECT(交
集)和UNIONALL。。。
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
sql中union多表合并耗时:1.14 sec
  der_id FROM made_order a
  der_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.不能排序,如果要对结果排序,可以在集合运算后,外⾯再套⼀个查询,然后排序,如前⾯的例⼦可以改成:
SELECT * FROM
(SELECT order_id FROM made_order
  MINUS
  SELECT order_id FROM charge_detail)
ORDER BY ORDER_ID ASC

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。