利用 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 語句如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
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 語句如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
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
|
+------+------------+---------+
|
原文:https://blog.csdn.net/qq_41573234/article/details/80292679
(轉載請注明花兒為何那樣紅博客)