Oracle基礎知識:集合運算
最新學訊:近期OCP認證正在報名中,因考試人員較多請盡快報名獲取最近考試時間,報名費用請聯系在線老師,甲骨文官方認證,報名從速!
我要咨詢Oracle基礎知識:集合運算,集合運算就是將兩個或者多個結果集組合成為一個結果集。集合運算包括:
··INTERSECT(交集),返回兩個查詢共有的記錄。
··UNION ALL(并集),返回各個查詢的所有記錄,包括重復記錄。
··UNION(并集),返回各個查詢的所有記錄,不包括重復記錄。
··MINUS(補集),返回第一個查詢檢索出的記錄減去第二個查詢檢索出的記錄之后剩余的記錄。
當使用集合操作的時候,要注意:查詢所返回的列數以及列的類型必須匹配,列名可以不同。
案例6:查詢出dept表中哪個部門下沒有員工。只需求出dept表中的部門號和emp表中的部門號的補集即可。
代碼演示:求補運算
SQL> SELECT DEPTNO FROM DEPT
2 MINUS
3 SELECT DEPTNO FROM EMP; DEPTNO ------
40 |
前面學習過可以通過insert into …select把一個結果集插入到另一張結構相同的表中,因此可以使用union把若干條記錄一次性插入到一張表中。
代碼演示:用union插入多條數據
SQL> INSERT INTO DEPT
2 SELECT 50,'公關部','臺灣'
FROM DUAL
3 UNION
4 SELECT 60,'研發部','西安'
FROM DUAL
5 UNION
6 SELECT 70,'培訓部','西安'
FROM DUAL
7 / 3 rows inserted |