Oracle:聚合运算
Oracle:集合运算用户scott下emp表:select deptno from deptemp表: select deptno from emporacle集合函数
Oracle:集合运算
用户scott下
emp表:
select deptno from dept

emp表:
select deptno from emp

oracle集合函数包括:minus(差集),union(并集),union all(不排重并集),intersect(交集)
1.minus:找到两个给定的数值集合之间的差异,意味着找到一个数值集合,其中的元素仅存在于前一个集合中,而不存在于另一个集合中。
select deptno from dept minus select deptno from emp

分析:查相同列名的数据,查出的40,只存在与前一张表,即dept表中。
2.union:连接查询的两张表中相同列名的数据的并集。
select deptno from dept union select deptno from emp

分析:查出2张表中的并集。
3.union all:连接查询两张表中相同列名的所有数据。(与union 不同的是它不去除重复数据)。
select deptno from dept union all select deptno from emp

分析:查出2张表中所有的值。
4.intersect:查询intersect连接的两张表中相同列名的数据,查出交集的数据。
select deptno from dept intersectselect deptno from emp

分析:查出2张表中所有的交集。
5.举个例子说明集合运算的应用:
查询出没有员工的那个部门的部门编号和部门名称.
(1).平常做法:
select deptno,dname from dept where deptno not in (select distinct (deptno) from emp)

(2).使用minus做法:
select deptno,dname from dept where deptno in (select deptno from dept minus select deptno from emp)

结果:(一样)