sqlserver Union和SQL Union All使用方法_MsSql

來源:互聯網
上載者:User

SQL UNION 操作符

UNION 操作符用於合并兩個或多個 SELECT 語句的結果集。

請注意,UNION 內部的 SELECT 語句必須擁有相同數量的列。列也必須擁有相似的資料類型。同時,每條 SELECT 語句中的列的順序必須相同。

SQL UNION 文法
SELECT column_name(s) FROM table_name1
UNION
SELECT column_name(s) FROM table_name2

注釋:預設地,UNION 操作符選取不同的值,即UNION是去了重的。如果允許重複的值,請使用 UNION ALL

SQL UNION ALL 文法
SELECT column_name(s) FROM table_name1
UNION ALL
SELECT column_name(s) FROM table_name2

另外,UNION 結果集中的列名總是等於 UNION 中第一個 SELECT 語句中的列名。

UNION 指令的目的是將兩個 SQL 陳述式的結果合并起來。從這個角度來看, UNION 跟 JOIN 有些許類似,因為這兩個指令都可以由多個表格中擷取資料。union只是將兩個結果連接起來一起顯示,並不是連接兩個表………… UNION 的文法如下:

 [SQL 陳述式 1]
UNION
[SQL 陳述式 2]
假設我們有以下的兩個表格,

Store_Information 表格
store_name Sales Date
Los Angeles $1500 Jan-05-1999
San Diego $250 Jan-07-1999
Los Angeles $300 Jan-08-1999
Boston $700 Jan-08-1999
Internet Sales 表格
Date Sales
Jan-07-1999 $250
Jan-10-1999 $535
Jan-11-1999 $320
Jan-12-1999 $750

而我們要找出來所有有營業額 (sales) 的日子。要達到這個目的,我們用以下的 SQL 陳述式: SELECT Date FROM Store_Information
UNION
SELECT Date FROM Internet_Sales
結果:

Date
Jan-05-1999
Jan-07-1999
Jan-08-1999
Jan-10-1999
Jan-11-1999
Jan-12-1999

有一點值得注意的是,如果我們在任何一個 SQL 陳述式 (或是兩句都一起) 用 "SELECT DISTINCT Date" 的話,那我們會得到完全一樣的結果。

SQL Union All
UNION ALL 這個指令的目的也是要將兩個 SQL 陳述式的結果合并在一起。 UNION ALLUNION 不同之處在於 UNION ALL 會將每一筆合格資料都列出來,無論資料值有無重複。 UNION ALL 的文法如下: [SQL 陳述式 1]
UNION ALL
[SQL 陳述式 2]
我們用和上一頁同樣的例子來顯示出 UNION ALLUNION 的不同。同樣假設我們有以下兩個表格,

Store_Information 表格
store_name Sales Date
Los Angeles $1500 Jan-05-1999
San Diego $250 Jan-07-1999
Los Angeles $300 Jan-08-1999
Boston $700 Jan-08-1999
Internet Sales 表格
Date Sales
Jan-07-1999 $250
Jan-10-1999 $535
Jan-11-1999 $320
Jan-12-1999 $750

而我們要找出有店面營業額以及網路營業額的日子。要達到這個目的,我們用以下的 SQL 陳述式: SELECT Date FROM Store_Information
UNION ALL
SELECT Date FROM Internet_Sales
結果:

Date
Jan-05-1999
Jan-07-1999
Jan-08-1999
Jan-08-1999
Jan-07-1999
Jan-10-1999
Jan-11-1999
Jan-12-1999

 eg:

複製代碼 代碼如下:

SELECT id,Name,DocPinYin FROM doctor
UNION
SELECT 0 AS id,'無醫生名' AS Name,'' AS DocPinYin


結果集是

SELECT id,Name,DocPinYin FROM doctor

結果集是

故:union將兩個結果集合在一起

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.