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 ALL。
SQL UNION ALL 語法
SELECT column_name(s) FROM table_name1 UNION ALL SELECT column_name(s) FROM table_name2
另外,UNION 結果集中的列名總是等於 UNION 中第一個 SELECT 語句中的列名。
一、前期准備:
drop table if exists empCN; create table empCN (ID INT,Name VARCHAR(20)); drop table if exists empUSA; create table empUSA (ID INT,Name VARCHAR(20)); -- 插入數據 insert into empCN(ID,Name) VALUES(1,'ZhangHua'); insert into empCN(ID,Name) VALUES(2,'WangWei'); insert into empCN(ID,Name) VALUES(3,'Cart Thomas'); insert into empCN(ID,Name) VALUES(4,'YangMing'); insert into empUSA(ID,Name) VALUES(1,'Adams John'); insert into empUSA(ID,Name) VALUES(2,'Bush George'); insert into empUSA(ID,Name) VALUES(3,'Cart Thomas'); insert into empUSA(ID,Name) VALUES(4,'Gates Bill'); -- 增加Column Alter table empCN ADD COLUMN(score int); Alter table empUSA ADD COLUMN(score int); UPDATE empcn set score=20 where ID=1; UPDATE empcn set score=60 where ID=2; UPDATE empcn set score=80 where ID=3; UPDATE empcn set score=90 where ID=4; UPDATE empusa set score=20 where ID=1; UPDATE empusa set score=45 where ID=2; UPDATE empusa set score=29 where ID=3; UPDATE empusa set score=68 where ID=4;
二、操作語句
-- 區分UNION 與 UNION ALL -- union 消除重復數據 SELECT * FROM empCN UNION SELECT * FROM empusa; -- 重復數據同樣顯示 SELECT * FROM empCN UNION ALL SELECT * FROM empusa; -- 數據求和 必須為UNION ALL后的數據加 表別名alisa SELECT id,name,sum(score) FROM (SELECT * FROM empCN UNION ALL SELECT * FROM empusa) a group by id,name;
三、結果分析