日期:2014-05-16  浏览次数:20573 次

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 
intersect
select 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
) 




结果:(一样)