UNION ALL 與UNION 是MySQL能使用的聯集查詢,兩種語法相同但是效果不同,以下將會舉例介紹。
語法︰
<SELECT查詢一>
UNION [ALL]
<SELECT查詢二>
使用UNION ALL,會將上下兩個查詢的結果全部都列出來。
SELECT *
FROM user_order
LEFT JOIN
user
ON
user.id = user_order.user_id
UNION ALL
SELECT *
FROM user_order
RIGHT JOIN
user
ON
user.id = user_order.user_id
結果︰兩種查詢結果都會逐一呈現
使用UNION,當上下兩結果集合併時,將會把相同的結果排除重複,呈現不重複的資料結果
SELECT *
FROM user_order
LEFT JOIN
user
ON
user.id = user_order.user_id
UNION
SELECT *
FROM user_order
RIGHT JOIN
user
ON
user.id = user_order.user_id
結果:只呈現出兩種查詢不重複的資料結果
上方所示UNION語句範例,同時具有FULL OUTER JOIN的功能,但MySQL並不支援FULL OUTER JOIN,所以如果有需要使用到FULL OUTER JOIN的人可以使用上方所示的語法去做
其它文章
留言列表