Oracle 集合操作符__Oracle

來源:互聯網
上載者:User

-- Start

Oracle 支援如下幾個集合操作符。

UNION        用來求兩個集合的並集,並去掉重複值UNION ALL    用來求兩個集合的並集INTERSECT    用來求兩個集合的交集,並去掉重複值MINUS        用來求在第一個集合中存在,而在第二個集合中不存在的記錄,並去掉重複值

下面我們先來準備測試資料。

CREATE TABLE TEST_LEFT(    COL CHAR);INSERT INTO TEST_LEFT VALUES ('A');INSERT INTO TEST_LEFT VALUES ('A');INSERT INTO TEST_LEFT VALUES ('B');INSERT INTO TEST_LEFT VALUES ('B');INSERT INTO TEST_LEFT VALUES ('C');CREATE TABLE TEST_RIGHT(    COL CHAR);INSERT INTO TEST_RIGHT VALUES ('A');INSERT INTO TEST_RIGHT VALUES ('B');INSERT INTO TEST_RIGHT VALUES ('B');INSERT INTO TEST_RIGHT VALUES ('D');INSERT INTO TEST_RIGHT VALUES ('E');

下面我們通過一個例子來對比一下它們直接的不同。

---UNIONSELECT * FROM TEST_LEFTUNIONSELECT * FROM TEST_RIGHT;---結果ABCDE---UNION ALLSELECT * FROM TEST_LEFTUNION ALLSELECT * FROM TEST_RIGHT;---結果AABBCABBDE---INTERSECTSELECT * FROM TEST_LEFTINTERSECTSELECT * FROM TEST_RIGHT;---結果AB---MINUSSELECT * FROM TEST_LEFTMINUSSELECT * FROM TEST_RIGHT;---結果C

大家對比一下它們之間的結果就可以看出它們之間的區別,不過有個問題需要注意:

UNION 和 INTERSECT 兩別集合可以互換的,但是 MINUS 互換將有不同的結果,如下:

---語句1SELECT * FROM TEST_LEFTMINUSSELECT * FROM TEST_RIGHT;---結果C---語句2SELECT * FROM TEST_RIGHTMINUSSELECT * FROM TEST_LEFT;---結果DE

-- 更多參見:Oracle SQL 精萃

-- 聲明:轉載請註明出處

-- Last Edited on 2014-12-17

-- Created by ShangBo on 2014-12-17

-- End

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.