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

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

  • 3
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
在 PL/SQL UNIONUNION ALL、MINUS 和 INTERSECT 是用于合并和比较结果集的操作符。它们之间的区别如下: 1. UNIONUNION 操作符用于合并两个或多个 SELECT 语句的结果集,并去除重复的行。它返回一个包含所有唯一行的结果集。 2. UNION ALL:UNION ALL 操作符也用于合并两个或多个 SELECT 语句的结果集,但不去除重复的行。它返回一个包含所有行的结果集,包括重复的行。 3. MINUS:MINUS 操作符用于从第一个 SELECT 语句的结果集减去第二个 SELECT 语句的结果集,返回在第一个结果集存在但不在第二个结果集的行。它会去除重复的行。 4. INTERSECTINTERSECT 操作符用于返回同时存在于两个 SELECT 语句结果集的行,即交集。它会去除重复的行。 需要注意的是,这些操作符在比较结果集时要求两个 SELECT 语句具有相同的列数和相同或兼容的数据类型。 下面是一个示例: ``` SELECT column1 FROM table1 UNION SELECT column1 FROM table2; ``` 这将返回两个表 column1 列的唯一值。 ``` SELECT column1 FROM table1 UNION ALL SELECT column1 FROM table2; ``` 这将返回两个表 column1 列的所有值,包括重复的值。 ``` SELECT column1 FROM table1 MINUS SELECT column1 FROM table2; ``` 这将返回只在 table1 存在但不在 table2 存在的行。 ``` SELECT column1 FROM table1 INTERSECT SELECT column1 FROM table2; ``` 这将返回同时在 table1 和 table2 存在的行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值