Oracle的集合操作(union、union all、intersect、minus集合函式)

Z少校發表於2020-04-03

Oracle中的集合操作用於多條select語句合併結果。用於集合操作的函式如下:


union               並集 去重   //預設有排序操作

union all         並集 不去重   //預設不排序

intersect         交集     //並且去重排序

minus              差集     //  前表中有,後表中沒有的差集


1.union

A集合和B集合的合併,但去掉兩集合重複的部分 會排序。

示例:

select deptno,ename from emp where deptno in (20,30)
union
select deptno,ename from emp where deptno in (20,10);
    DEPTNO ENAME
---------- ----------
10 CLARK
10 KING
10 MILLER
20 ADAMS
20 FORD
20 JONES
20 SCOTT
20 SMITH
30 ALLEN
30 BLAKE
30 JAMES
30 MARTIN
30 TURNER
30 WARD
14 rows selected.



2.union all

A集合和B集合的合併,不去重,不排序。

示例:

select deptno,ename from emp where deptno in (20,30)
union all
select deptno,ename from emp where deptno in (20,10);
    DEPTNO ENAME
---------- ----------
20 SMITH
30 ALLEN
30 WARD
20 JONES
30 MARTIN
30 BLAKE
20 SCOTT
30 TURNER
20 ADAMS
30 JAMES
20 FORD
20 SMITH
20 JONES
10 CLARK
20 SCOTT
10 KING
20 ADAMS
20 FORD
10 MILLER
19 rows selected.



3.intersect

兩個集合的交集部分,排序並去重。

示例:

select deptno,ename from emp where deptno in (20,30)
intersect
select deptno,ename from emp where deptno in (20,10);
    DEPTNO ENAME
---------- ----------
20 ADAMS
20 FORD
20 JONES
20 SCOTT
20 SMITH
5 rows selected


4.minus

取兩個集合的差集,A集合中存在,B集合中不存在的資料(取A集合中B集合不存在的資料) 去重。

示例:

select deptno,ename from emp where deptno in (20,30)
minus
select deptno,ename from emp where deptno in (20,10);
    DEPTNO ENAME
---------- ----------
30 ALLEN
30 BLAKE
30 JAMES
30 MARTIN
30 TURNER
30 WARD
6 rows selected.


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30484956/viewspace-2684310/,如需轉載,請註明出處,否則將追究法律責任。

相關文章