一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - Mysql - Mysql聯(lián)合查詢(xún)UNION和UNION ALL的使用介紹

Mysql聯(lián)合查詢(xún)UNION和UNION ALL的使用介紹

2020-03-24 15:09MYSQL教程網(wǎng) Mysql

本文詳細(xì)介紹了Mysql的聯(lián)合查詢(xún)命令UNION和UNION ALL,總結(jié)了使用語(yǔ)法和注意事項(xiàng),以及學(xué)習(xí)例子和項(xiàng)目例子,需要的朋友可以參考下

一、UNION和UNION ALL的作用和語(yǔ)法

UNION 用于合并兩個(gè)或多個(gè) SELECT 語(yǔ)句的結(jié)果集,并消去表中任何重復(fù)行。
UNION 內(nèi)部的 SELECT 語(yǔ)句必須擁有相同數(shù)量的列,列也必須擁有相似的數(shù)據(jù)類(lèi)型。
同時(shí),每條 SELECT 語(yǔ)句中的列的順序必須相同.
SQL UNION 語(yǔ)法:

復(fù)制代碼 代碼如下:
SELECT column_name FROM table1
UNION
SELECT column_name FROM table2


注釋?zhuān)耗J(rèn)地,UNION 操作符選取不同的值。如果允許重復(fù)的值,請(qǐng)使用 UNION ALL。
當(dāng) ALL 隨 UNION 一起使用時(shí)(即 UNION ALL),不消除重復(fù)行
SQL UNION ALL 語(yǔ)法

復(fù)制代碼 代碼如下:
SELECT column_name FROM table1
UNION ALL
SELECT column_name FROM table2


注釋?zhuān)毫硗猓琔NION 結(jié)果集中的列名總是等于 UNION 中第一個(gè) SELECT 語(yǔ)句中的列名。
注意:1、UNION 結(jié)果集中的列名總是等于第一個(gè) SELECT 語(yǔ)句中的列名
2、UNION 內(nèi)部的 SELECT 語(yǔ)句必須擁有相同數(shù)量的列。列也必須擁有相似的數(shù)據(jù)類(lèi)型。同時(shí),每條 SELECT 語(yǔ)句中的列的順序必須相同

 


二、union的用法及注意事項(xiàng)

union:聯(lián)合的意思,即把兩次或多次查詢(xún)結(jié)果合并起來(lái)。
要求:兩次查詢(xún)的列數(shù)必須一致
推薦:列的類(lèi)型可以不一樣,但推薦查詢(xún)的每一列,想對(duì)應(yīng)的類(lèi)型以一樣
可以來(lái)自多張表的數(shù)據(jù):多次sql語(yǔ)句取出的列名可以不一致,此時(shí)以第一個(gè)sql語(yǔ)句的列名為準(zhǔn)。
如果不同的語(yǔ)句中取出的行,有完全相同(這里表示的是每個(gè)列的值都相同),那么union會(huì)將相同的行合并,最終只保留一行。也可以這樣理解,union會(huì)去掉重復(fù)的行。
如果不想去掉重復(fù)的行,可以使用union all。
如果子句中有order by,limit,需用括號(hào)()包起來(lái)。推薦放到所有子句之后,即對(duì)最終合并的結(jié)果來(lái)排序或篩選。
如:

復(fù)制代碼 代碼如下:
(select * from a order by id) union (select * from b order id);

 

在子句中,order by 需要配合limit使用才有意義。如果不配合limit使用,會(huì)被語(yǔ)法分析器優(yōu)化分析時(shí)去除。

三、學(xué)習(xí)例子

下面的例子中使用的原始表:
Employees_China:

復(fù)制代碼 代碼如下:
E_ID E_Name
01 Zhang, Hua
02 Wang, Wei
03 Carter, Thomas
04 Yang, Ming


Employees_USA:

復(fù)制代碼 代碼如下:
E_ID E_Name
01 Adams, John
02 Bush, George
03 Carter, Thomas
04 Gates, Bill

 

使用 UNION 命令實(shí)例

列出所有在中國(guó)和美國(guó)的不同的雇員名:

復(fù)制代碼 代碼如下:
SELECT E_Name FROM Employees_China
UNION
SELECT E_Name FROM Employees_USA


結(jié)果:

復(fù)制代碼 代碼如下:
E_Name
Zhang, Hua
Wang, Wei
Carter, Thomas
Yang, Ming
Adams, John
Bush, George
Gates, Bill


注釋?zhuān)哼@個(gè)命令無(wú)法列出在中國(guó)和美國(guó)的所有雇員。在上面的例子中,我們有兩個(gè)名字相同的雇員,他們當(dāng)中只有一個(gè)人被列出來(lái)了。UNION 命令只會(huì)選取不同的值。

 

使用 UNION ALL 命令實(shí)例

UNION ALL 命令和 UNION 命令幾乎是等效的,不過(guò) UNION ALL 命令會(huì)列出所有的值。

復(fù)制代碼 代碼如下:
SQL Statement 1
UNION ALL
SQL Statement 2

 

實(shí)例:
列出在中國(guó)和美國(guó)的所有的雇員:

復(fù)制代碼 代碼如下:
SELECT E_Name FROM Employees_China
UNION ALL
SELECT E_Name FROM Employees_USA


結(jié)果

復(fù)制代碼 代碼如下:
E_Name
Zhang, Hua
Wang, Wei
Carter, Thomas
Yang, Ming
Adams, John
Bush, George
Carter, Thomas
Gates, Bill

 


四、項(xiàng)目使用例子

web項(xiàng)目中經(jīng)常會(huì)碰到整站搜索的問(wèn)題,即客戶(hù)希望在網(wǎng)站的搜索框中輸入一個(gè)詞語(yǔ),然后在整個(gè)網(wǎng)站中只要包含這個(gè)詞的頁(yè)面都要出現(xiàn)在搜索結(jié)果中。由于一個(gè)web項(xiàng)目不可能用一張表就全部搞定的,所以這里一般都是要用union聯(lián)合搜索來(lái)解決整個(gè)問(wèn)題的。

下面列舉一下本次使用的union聯(lián)合搜索的sql語(yǔ)句:

 

復(fù)制代碼 代碼如下:


select * from

 

(SELECT `id`,`subject` FROM `article` WHERE `active`='1' AND `subject` LIKE '%調(diào)整圖片%' ORDER BY `add_time` DESC)

as t1

union all

select * from

(SELECT `id`,`class_name` AS `subject` FROM `web_class` WHERE `active`='1' AND `class_name` LIKE '%調(diào)整圖片%' ORDER BY `class_id` DESC)

as t2

union

select * from

(SELECT `id`,`subject` FROM `article` WHERE `active`='1' AND (`subject` LIKE '%調(diào)整%' OR `subject` LIKE '%圖片%') ORDER BY `add_time` DESC)

as t3;

 

以上SQL語(yǔ)句的聯(lián)合查詢(xún)主要用到了union all和union,至于這兩者的區(qū)別就是union all會(huì)列舉所有符合條件的查詢(xún)結(jié)果,而union會(huì)將所有符合條件的查詢(xún)結(jié)果做一下去除重復(fù)結(jié)果的篩選。

對(duì)于以上SQL語(yǔ)句的解釋就是由于article表和web_class表分屬兩個(gè)不同的表,所以這里不用去除重復(fù)結(jié)果。然而以上聯(lián)合查詢(xún)的第三個(gè)分支的sql查詢(xún)語(yǔ)句是由分詞然后組合出來(lái)的查詢(xún)語(yǔ)句,這條sql語(yǔ)句查詢(xún)的結(jié)果是肯定包含第一個(gè)分支sql語(yǔ)句的查詢(xún)結(jié)果的,這里就顯得沒(méi)必要了,所以沒(méi)有使用all而去掉重復(fù)的查詢(xún)結(jié)果。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久嫩草影院网站 | 免费国产之a视频 | 国产精品视频一区二区三区w | 欧美性xxxxx 欧美性bbbbbxxxxxddd | 久久五月综合婷婷中文云霸高清 | 亚洲偷窥图区色 | 亚洲AV 日韩 国产 有码 | 暖暖视频免费观看视频中国.韩剧 | 国内外成人在线视频 | 午夜在线观看视频 | 香蕉tv国产在线永久播放 | 日韩欧美成末人一区二区三区 | 香蕉久久一区二区三区啪啪 | 含羞草传媒每天免费一次破解 | 国产精品免费看久久久香蕉 | 好大好深好涨好烫还要 | 白丝美女用胸伺候主人 | 艾秋果冻麻豆老狼 | 私人影院免费观看 | 国产精品永久免费10000 | 男女视频在线观看网站 | 国产nv精品你懂得 | 99热这里只有精品国产免费 | 小sao货水好多真紧h的视频 | 91亚洲一区二区在线观看不卡 | 日本 在线观看 | 色婷婷综合久久久中文字幕 | www.com日本| 西野翔全部作品在线观看 | 亚洲精品在线免费观看视频 | 亚洲精品久久玖玖玖玖 | 欧美午夜网站 | 海派甜心完整版在线观看 | 欧美亚洲桃花综合 | 天天射天天舔 | 亚洲精品乱码久久久久久蜜桃 | 四虎在线免费播放 | 高清视频在线播放ww | 性欧美sexovideotv | 女王脚奴vk | 亚洲性久久久影院 |