1. 程式人生 > >MySQL——合併查詢結果

MySQL——合併查詢結果

    利用  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 語句如下:

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 |
+------+------------+---------+
【例】查詢所有價格小於  9  的水果的資訊,查詢  s_id 等於 101 和 103 的所有水果的資訊,使用  UNION ALL 連線查詢結果。SQL 語句如下:
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版