NION 操作符
UNION 操作符用于合并兩個或多個 SELECT 語句的結果集。
請注意,UNION 內(nèi)部的 SELECT 語句必須擁有相同數(shù)量的列。列也必須擁有相似的數(shù)據(jù)類型。同時,每條 SELECT 語句中的列的順序必須相同。
SQL UNION 語法
SELECT?column_name(s)?FROM?table_name1 UNION SELECT?column_name(s)?FROM?table_name2
注釋:默認地,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 語句中的列名。
下面的例子中使用的原始表: Employees_China:01 Zhang, Hua 02 Wang, Wei 03 Carter, Thomas 04 Yang, Ming Employees_USA:01 Adams, John 02 Bush, George 03 Carter, Thomas 04 Gates, Bill 使用 UNION 命令 實例
列出所有在中國和美國的不同的雇員名:
SELECT?E_Name?FROM?Employees_ChinaUNIONSELECT?E_Name?FROM?Employees_USA
結果Zhang, Hua Wang, Wei Carter, Thomas Yang, Ming Adams, John Bush, George Gates, Bill
注釋:這個命令無法列出在中國和美國的所有雇員。在上面的例子中,我們有兩個名字相同的雇員,他們當中只有一個人被列出來了。UNION 命令只會選取不同的值。
UNION ALL
UNION ALL 命令和 UNION 命令幾乎是等效的,不過 UNION ALL 命令會列出所有的值。
SQL?Statement?1 UNION?ALL SQL?Statement?2
使用 UNION ALL 命令 實例:
列出在中國和美國的所有的雇員:
SELECT?E_Name?FROM?Employees_ChinaUNION?ALLSELECT?E_Name?FROM?Employees_USA
結果Zhang, Hua
Wang, Wei
Carter, Thomas
Yang, Ming
Adams, John
Bush, George
Carter, Thomas
Gates, Bill
E_ID | E_Name | E_ID | E_Name | E_Name | E_Name |
---|