SQL Union / Union All

UNION 指令的目的是將兩個 SQL 語句的結果合併起來。從這個角度來看, UNION 跟 JOIN 有些許類似,因爲這兩個指令都可以由多個表格中擷取資料。 UNION 的一個限制是兩個 SQL 語句所產生的欄位需要是同樣的資料種類。另外,當我們用 UNION這個指令時,我們只會看到不同的資料值 (類似 SELECT DISTINCT)。 union只是將兩個結果聯結起來一起顯示,並不是聯結兩個表………… UNION 的語法如下: [SQL 語句 1]
UNION
[SQL 語句 2]
 假設我們有以下的兩個表格,[table][tr][td]Store_Information 表格[table][tr][td]store_name[/td][td]Sales [/td][td]Date [/td][/tr][tr][td]Los Angeles [/td][td]$1500 [/td][td]Jan-05-1999 [/td][/tr][tr][td]San Diego [/td][td]$250 [/td][td]Jan-07-1999 [/td][/tr][tr][td]Los Angeles [/td][td]$300 [/td][td]Jan-08-1999 [/td][/tr][tr][td]Boston [/td][td]$700 [/td][td]Jan-08-1999 [/td][/tr][/table][/td][/tr][tr][td]Internet Sales 表格[table][tr][td]Date [/td][td]Sales [/td][/tr][tr][td]Jan-07-1999 [/td][td]$250 [/td][/tr][tr][td]Jan-10-1999 [/td][td]$535[/td][/tr][tr][td]Jan-11-1999 [/td][td]$320 [/td][/tr][tr][td]Jan-12-1999 [/td][td]$750 [/td][/tr][/table][/td][/tr][/table]而我們要找出來所有有營業額 (sales) 的日子。要達到這個目的,我們用以下的 SQL 語句: SELECT Date FROM Store_Information
UNION
SELECT Date FROM Internet_Sales
 結果:[table][tr][td]Date[/td][/tr][tr][td]Jan-05-1999[/td][/tr][tr][td]Jan-07-1999[/td][/tr][tr][td]Jan-08-1999[/td][/tr][tr][td]Jan-10-1999[/td][/tr][tr][td]Jan-11-1999[/td][/tr][tr][td]Jan-12-1999[/td][/tr][/table]有一點值得注意的是,如果我們在任何一個 SQL 語句 (或是兩句都一起) 用 "SELECT DISTINCT Date" 的話,那我們會得到完全一樣的結果。

SQL Union All
UNION ALL 這個指令的目的也是要將兩個 SQL 語句的結果合併在一起。 UNION ALL 和 UNION 不同之處在於 UNION ALL 會將每一筆符合條件的資料都列出來,無論資料值有無重複。 UNION ALL 的語法如下:[SQL 語句 1]
UNION ALL
[SQL 語句 2]
 我們用和上一頁同樣的例子來顯示出 UNION ALL 和 UNION 的不同。同樣假設我們有以下兩個表格,[table][tr][td]Store_Information 表格[table][tr][td]store_name [/td][td]Sales [/td][td]Date [/td][/tr][tr][td]Los Angeles [/td][td]$1500 [/td][td]Jan-05-1999 [/td][/tr][tr][td]San Diego [/td][td]$250 [/td][td]Jan-07-1999 [/td][/tr][tr][td]Los Angeles [/td][td]$300 [/td][td]Jan-08-1999 [/td][/tr][tr][td]Boston [/td][td]$700 [/td][td]Jan-08-1999 [/td][/tr][/table][/td][/tr][tr][td]Internet Sales 表格[table][tr][td]Date [/td][td]Sales [/td][/tr][tr][td]Jan-07-1999 [/td][td]$250 [/td][/tr][tr][td]Jan-10-1999 [/td][td]$535 [/td][/tr][tr][td]Jan-11-1999 [/td][td]$320 [/td][/tr][tr][td]Jan-12-1999 [/td][td]$750 [/td][/tr][/table][/td][/tr][/table]而我們要找出有店面營業額以及網絡營業額的日子。要達到這個目的,我們用以下的 SQL 語句: SELECT Date FROM Store_Information
UNION ALL
SELECT Date FROM Internet_Sales
 結果:[table][tr][td]Date[/td][/tr][tr][td]Jan-05-1999[/td][/tr][tr][td]Jan-07-1999[/td][/tr][tr][td]Jan-08-1999[/td][/tr][tr][td]Jan-08-1999[/td][/tr][tr][td]Jan-07-1999[/td][/tr][tr][td]Jan-10-1999[/td][/tr][tr][td]Jan-11-1999[/td][/tr][tr][td]Jan-12-1999[/td][/tr][/table]

發佈了64 篇原創文章 · 獲贊 4 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章