MySQL——合併查詢結果
阿新 • • 發佈:2019-01-10
利用 UNION 關鍵字,可以給出多條 SELECT 語句,並將它們的結果組合成一個結果集。合併時,兩個表對應的列數和資料型別必須相同。SELECT 語句之間使用 UNION 或 UNION ALL 關鍵字分隔。不使用關鍵字 ALL,執行的時候會刪除重複的記錄,所有返回的行都是唯一的;使用關鍵宇 ALL 的作用是不刪除重複行也不對結果進行自動排序。
基本的語法格式如下:
SELECT column,.... FROM table1
UNION [ALL]
SELECT column ,... FROM table2
【例】查詢所有價格小於 9 的水果的資訊,查詢 s_id 等於 101 和 103 的所有水果的資訊,使用 UNION 連線查詢結果。SQL 語句如下:
【例】查詢所有價格小於 9 的水果的資訊,查詢 s_id 等於 101 和 103 的所有水果的資訊,使用 UNION ALL 連線查詢結果。SQL 語句如下:mysql> SELECT s_id, f_name, f_price -> FROM fruits -> WHERE f_price < 9.0 -> UNION ALL -> SELECT s_id,f_name ,f_price -> FROM fruits -> WHERE s_id In(101,103); +------+------------+---------+ | s_id | f_name | f_price | +------+------------+---------+ | 101 | apple | 5.20 | | 103 | apricot | 2.20 | | 104 | berry | 7.60 | | 107 | xxxx | 3.60 | | 105 | melon | 8.20 | | 101 | cherry | 3.20 | | 104 | lemon | 6.40 | | 105 | xbabay | 2.60 | | 102 | grape | 5.30 | | 107 | xbababa | 3.60 | | 101 | apple | 5.20 | | 103 | apricot | 2.20 | | 101 | blackberry | 10.20 | | 101 | cherry | 3.20 | | 103 | coconut | 9.20 | +------+------------+---------+
mysql> SELECT s_id, f_name, f_price -> FROM fruits -> WHERE f_price < 9.0 -> UNION -> SELECT s_id, f_name, f_price -> FROM fruits -> WHERE s_id In(101,103); +------+------------+---------+ | s_id | f_name | f_price | +------+------------+---------+ | 101 | apple | 5.20 | | 103 | apricot | 2.20 | | 104 | berry | 7.60 | | 107 | xxxx | 3.60 | | 105 | melon | 8.20 | | 101 | cherry | 3.20 | | 104 | lemon | 6.40 | | 105 | xbabay | 2.60 | | 102 | grape | 5.30 | | 107 | xbababa | 3.60 | | 101 | blackberry | 10.20 | | 103 | coconut | 9.20 | +------+------------+---------+
【注】參考於清華大學出版社《MySQL資料庫應用案例課堂》2016年1月第1版