集合操作UNION、UNION ALL、INTERSECT、MINUS区别

有两个表job_history表有10条数据;employees表有107条数据,这两个表有2条数据是重复的
SQL> ed
已写入 file afiedt.buf
  1  SELECT employee_id id, job_id
  2  FROM   employees
  3  minus
  4  SELECT employee_id id, job_id
  5* FROM   job_history
SQL> /
表示返回在employees中存在,而不在job_history中的记录,返回105条数据,去掉了2条重复的数据
SQL> ed
已写入 file afiedt.buf
  1  SELECT employee_id id, job_id
  2  FROM   job_history
  3  minus
  4  SELECT employee_id id, job_id
  5* FROM   employees
SQL> /
表示返回在job_history中存在,而不在employees中的记录,返回8条数据,去掉了2条重复的数据

 

集合操作中的ORDER BY子句

只能在整个集合的最后出现.可以按照第一个SELECT语句中的列名, 别名或者位置号排序.
SQL> ed
已写入 file afiedt.buf
  1  SELECT employee_id id, job_id
  2  FROM   employees
  3  UNION all
  4  SELECT employee_id, job_id
  5  FROM   job_history
  6* order by employee_id
SQL> /
 
下面的语句是正确的
SQL> ed
已写入 file afiedt.buf
  1  SELECT employee_id, job_id
  2  FROM   employees
  3  UNION all
  4  SELECT employee_id id, job_id
  5  FROM   job_history
  6* order by employee_id
SQL> /

 

小结

在SELECT 列表中的表达是必须有同样的数目和类型.
在结果中显示第一个Select语句中的列名.
除了 UNION ALL操作外,其他的集合操作都自动去掉重复值.

所以其他操作会隐式的进行排序操作(sql语句中并没有order by),使用CPU资源.
除了UNION ALL操作外,其他集合操作的输出结果默认按照升序的次序排列 .

所以其他操作会隐式的进行排序操作(sql语句中并没有order by),使用CPU资源.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 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 存在的行。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值