oracle中有一类操作符是对集合进行操作的,我们称之为集合操作符(set operator),我们在前面已经分别介绍了每个集合操作符,这里简单总结一下,oracle中的集合操作符号主要有:
- union(all) 是用来将多个select语句的结果集合进行合并处理。其中union会压缩各个结果集中的重复数据,而union all则不会。
- intersect 是用来求两个集合的交集。
- minus是用来从一个结果集中去除另一个集合中包含的部分。
对与各个集合操作符, 需要注意的地方的如下:
- 除了union all之外的所有集合操作符号都会进行默认排序和去除重复行,这需要占用一定的资源,只有union all回将数据以原始的方式呈现出来。所以在对oracle中进行性能优化时尽量使用union all 而不是 union。
- 对于每一个查询中,必须要具有相同的列的数目和列的类型,但没有必要使列名相同。如果类型不一样,可以使用类型转换函数来转换。注意这里oracle不会进行隐式转换,必须进行手动转换,如果列的个数不一样,可以使用替代列的方式来充当。
例如:
select ename,sal from emp where sal > 2000
union all
select to_char(empno),0 from emp where sal >3500;
这里我们使用了类型转换函数来to_char将empno转由数值型换为字符型,并给出了一个填充列0,来凑足和前一个查询的相同的列数。 - 可以使用order by 来进行手动的排序,但只能出现在最后一个查询的后面。而且order by 使用到的列只能使用第一个查询的列名或者别名,或者使用列的计数器。