欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql使用union合并查詢結(jié)果的實(shí)現(xiàn)

 更新時(shí)間:2025年08月26日 09:12:15   作者:荔枝吻  
本文詳細(xì)介紹了MySQL中UNION操作符的使用方法,UNION用于合并多個(gè)SELECT語(yǔ)句的結(jié)果集,要求各查詢列數(shù)相同、數(shù)據(jù)類型兼容且順序一致,具有一定的參考價(jià)值,感興趣的可以了解一下

前言

在數(shù)據(jù)查詢過(guò)程中,有時(shí)我們需要從多個(gè)查詢結(jié)果中獲取整合后的數(shù)據(jù),比如之前用寬表存了一個(gè)十個(gè)等級(jí)的指標(biāo),現(xiàn)在想對(duì)十級(jí)指標(biāo)進(jìn)行全量分析,這時(shí) UNION 就派上了大用場(chǎng)。本文將深入探討在 MySQL 中如何使用 UNION 合并查詢結(jié)果,帶你全面了解其用法、注意事項(xiàng)及實(shí)際應(yīng)用場(chǎng)景,助力你更高效地處理數(shù)據(jù)查詢需求。

一、UNION 的基本概念

在 MySQL 中,UNION 操作符用于將兩個(gè)或多個(gè) SELECT 語(yǔ)句的結(jié)果集合并成一個(gè)結(jié)果集。它能夠幫助我們把來(lái)自不同查詢的數(shù)據(jù)整合在一起,方便后續(xù)的數(shù)據(jù)處理與分析。

SQL 標(biāo)準(zhǔn)中定義了 3 個(gè)集合操作符: UNION, INTERSECT 和 MINUS。目前 MySQL 只支持 【UNION】。

不過(guò)需要注意的是,使用 UNION 合并的各個(gè)查詢語(yǔ)句必須滿足以下條件:

  • 列數(shù)相同:所有 SELECT 語(yǔ)句中被選擇的列數(shù)要一致。
  • 對(duì)應(yīng)列的數(shù)據(jù)類型兼容:例如,第一個(gè) SELECT 語(yǔ)句中的某一列為整數(shù)類型,那么其他 SELECT 語(yǔ)句對(duì)應(yīng)位置的列也應(yīng)該是整數(shù)類型或者可以隱式轉(zhuǎn)換為整數(shù)類型。
  • 對(duì)應(yīng)列的順序一致:在結(jié)果集中,各列的順序是按照第一個(gè) SELECT 語(yǔ)句中的列順序來(lái)排列的,其他 SELECT 語(yǔ)句中的列順序也要與之對(duì)應(yīng)匹配。

二、UNION 的基本用法

UNION 操作符的語(yǔ)法如下:

SELECT statement
UNION [DISTINCT | ALL]
SELECT statement

UNION 操作包括 UNION DISTINCTUNION ALL 兩種算法,其中 UNION DISTINCT 可以簡(jiǎn)寫為 UNION。

1. 去重的 UNION 合并

假設(shè)我們有兩個(gè)表,一個(gè)是 “員工信息表 1”(employee1),另一個(gè)是 “員工信息表 2”(employee2),它們的結(jié)構(gòu)相似,都包含 “員工姓名”(name)和 “員工薪資”(salary)兩個(gè)字段?,F(xiàn)在我們想查詢兩個(gè)表中所有的員工姓名和薪資,可以使用以下 SQL 語(yǔ)句:

SELECT name, salary FROM employee1
UNION
SELECT name, salary FROM employee2;

這條語(yǔ)句會(huì)將兩個(gè)表中 “name” 和 “salary” 列的數(shù)據(jù)合并起來(lái),返回一個(gè)包含所有員工姓名和薪資的結(jié)果集。在這里,UNION 默認(rèn)會(huì)去除重復(fù)的行,也就是說(shuō),如果兩個(gè)表中有相同的員工姓名和薪資的組合記錄,最終結(jié)果中只會(huì)保留一行這樣的記錄。

2. 保留重復(fù)行的 UNION ALL

如果你希望在合并結(jié)果中保留所有的重復(fù)行,那么可以使用 UNION ALL。例如,在上述兩個(gè)員工信息表的例子中,我們想保留所有重復(fù)的員工記錄,可以這樣寫:

SELECT name, salary FROM employee1
UNION ALL
SELECT name, salary FROM employee2;

UNION 不同,UNION ALL 不會(huì)對(duì)結(jié)果進(jìn)行去重操作,因此執(zhí)行效率通常會(huì)比 UNION 高一些。在數(shù)據(jù)量較大且明確不需要去重的情況下,使用 UNION ALL 可以獲得更好的性能表現(xiàn)。

三、實(shí)際應(yīng)用場(chǎng)景

1. 整合不同數(shù)據(jù)源的數(shù)據(jù)

在實(shí)際業(yè)務(wù)場(chǎng)景中,數(shù)據(jù)可能分散在多個(gè)不同的表中,這些表可能對(duì)應(yīng)著不同的業(yè)務(wù)模塊或者不同的時(shí)間階段的數(shù)據(jù)。比如,在一個(gè)電商系統(tǒng)中,有 “訂單表 1”(order1)和 “訂單表 2”(order2),分別存儲(chǔ)了不同季度的訂單數(shù)據(jù),它們都有 “訂單號(hào)”(order_id)、“客戶名稱”(customer_name)、“訂單金額”(order_amount)等字段。當(dāng)我們需要分析整個(gè)年度的所有訂單情況時(shí),就可以使用 UNION 來(lái)合并這兩個(gè)表的數(shù)據(jù):

SELECT order_id, customer_name, order_amount FROM order1
UNION
SELECT order_id, customer_name, order_amount FROM order2;

這樣就能得到一個(gè)包含全年所有訂單信息的綜合結(jié)果集,方便進(jìn)行后續(xù)的數(shù)據(jù)統(tǒng)計(jì)和分析,如計(jì)算總銷售額、找出大客戶等。

2. 分頁(yè)查詢與合并

在處理大量數(shù)據(jù)進(jìn)行分頁(yè)查詢時(shí),有時(shí)需要先合并多個(gè)查詢結(jié)果,再進(jìn)行分頁(yè)操作。例如,我們有一個(gè) “文章表”(article),根據(jù)不同的分類(category)對(duì)文章進(jìn)行分組存儲(chǔ),現(xiàn)在我們想獲取所有分類中的熱門文章(假設(shè)熱門文章是指瀏覽量大于 1000 的文章),并將它們合并后進(jìn)行分頁(yè)展示,每頁(yè)顯示 10 條記錄:

SELECT id, title, views FROM article WHERE category = '科技' AND views > 1000
UNION
SELECT id, title, views FROM article WHERE category = '體育' AND views > 1000
UNION
SELECT id, title, views FROM article WHERE category = '娛樂(lè)' AND views > 1000
ORDER BY views DESC
LIMIT 0, 10;

這里先分別查詢每個(gè)分類中的熱門文章,然后通過(guò) UNION 合并結(jié)果,接著按照瀏覽量降序排列,最后使用 LIMIT 實(shí)現(xiàn)分頁(yè)查詢。這樣可以方便地獲取不同分類整合后的熱門文章數(shù)據(jù),并按照要求進(jìn)行展示。

3. 將合并后數(shù)據(jù)作為子查詢

在實(shí)際開發(fā)中,我們可能需要將 UNION 合并后的結(jié)果作為子查詢,再進(jìn)行進(jìn)一步的數(shù)據(jù)處理。比如,假設(shè)我們有一個(gè)電商系統(tǒng),訂單數(shù)據(jù)分布在 “訂單表 A”(order_a)和 “訂單表 B”(order_b)兩張表中,它們都有 “訂單號(hào)”(order_id)、“客戶 ID”(customer_id)和 “訂單金額”(amount)字段?,F(xiàn)在,我們想查詢每個(gè)客戶的總訂單金額,就可以先用 UNION ALL 合并兩張表的訂單數(shù)據(jù),再將合并后的結(jié)果作為子查詢,使用 GROUP BY 按客戶 ID 進(jìn)行分組求和:

SELECT customer_id, SUM(amount) AS total_amount
FROM (
    SELECT order_id, customer_id, amount FROM order_a
    UNION ALL
    SELECT order_id, customer_id, amount FROM order_b
) AS merged_orders
GROUP BY customer_id;

在這個(gè)例子中,我們先通過(guò) UNION ALL 將 order_a 和 order_b 表的數(shù)據(jù)合并成一個(gè)虛擬表 merged_orders,然后在這個(gè)虛擬表的基礎(chǔ)上,按照 customer_id 分組,計(jì)算每個(gè)客戶的總訂單金額。這樣,我們就能得到一個(gè)包含每個(gè)客戶及其對(duì)應(yīng)總訂單金額的結(jié)果集,滿足業(yè)務(wù)中對(duì)客戶消費(fèi)統(tǒng)計(jì)的需求。

3.1 合并字段名稱不同

比如我之前說(shuō)的用寬表存了一個(gè)十個(gè)等級(jí)的指標(biāo),現(xiàn)在想對(duì)十級(jí)指標(biāo)進(jìn)行全量分析,由于每個(gè)等級(jí)字段名稱不同,這時(shí)候記得命名別名進(jìn)行操作。

INSERT INTO index_item(index_item_name,index_item_num)
SELECT
	item,
	COUNT(*)
FROM(
	SELECT row_index_one AS item FROM index_record WHERE row_index_one IS NOT NULL
	UNION ALL
	SELECT row_index_two FROM index_record WHERE row_index_two IS NOT NULL
	UNION ALL
	SELECT row_index_three FROM index_record WHERE row_index_three IS NOT NULL
	UNION ALL
	SELECT row_index_four FROM index_record WHERE row_index_four IS NOT NULL
	UNION ALL
	SELECT row_index_five FROM index_record WHERE row_index_five IS NOT NULL
	UNION ALL
	SELECT row_index_six FROM index_record WHERE row_index_six IS NOT NULL
	UNION ALL
	SELECT row_index_seven FROM index_record WHERE row_index_seven IS NOT NULL
	UNION ALL
	SELECT row_index_eight FROM index_record WHERE row_index_eight IS NOT NULL
	UNION ALL
	SELECT row_index_nine FROM index_record WHERE row_index_nine IS NOT NULL
	UNION ALL
	SELECT row_index_ten FROM index_record WHERE row_index_ten IS NOT NULL
) AS items
GROUP BY item;

后記

雖然 UNION 和 UNION ALL 能夠方便地合并查詢結(jié)果,但在處理大數(shù)據(jù)量時(shí),性能可能會(huì)受到影響。特別是在使用 UNION 時(shí),由于需要進(jìn)行去重操作,MySQL 會(huì)額外消耗資源來(lái)比較和篩選重復(fù)的行。因此,在數(shù)據(jù)量較大的情況下,如果業(yè)務(wù)場(chǎng)景允許保留重復(fù)數(shù)據(jù),優(yōu)先考慮使用 UNION ALL。此外,對(duì)于復(fù)雜的多表 UNION 操作,我們可以通過(guò)優(yōu)化查詢語(yǔ)句、添加適當(dāng)?shù)乃饕确绞絹?lái)提高查詢性能。例如,在上述訂單表合并的例子中,如果 “order_id” 字段經(jīng)常用于查詢和合并操作,可以考慮為該字段添加索引,加快查詢速度。

到此這篇關(guān)于Mysql使用union合并查詢結(jié)果的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Mysql union合并查詢結(jié)果內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 允許遠(yuǎn)程訪問(wèn)MySQL的實(shí)現(xiàn)方式

    允許遠(yuǎn)程訪問(wèn)MySQL的實(shí)現(xiàn)方式

    這篇文章主要介紹了允許遠(yuǎn)程訪問(wèn)MySQL的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver 的區(qū)別

    com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver&n

    大家在連接mysql的時(shí)候,啟動(dòng)項(xiàng)目,會(huì)警告你推薦使用com.mysql.cj.jdbc.Driver?而不是com.mysql.jdbc.Driver,本文主要介紹了com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver 的區(qū)別,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • MySQL數(shù)據(jù)庫(kù)安全配置介紹

    MySQL數(shù)據(jù)庫(kù)安全配置介紹

    MySQL數(shù)據(jù)庫(kù)所在的主機(jī)的安全性是最首要的問(wèn)題,如果主機(jī)不安全,被攻擊者控制,那么MySQL的安全性也無(wú)從談起。其次就是數(shù)據(jù)目錄和數(shù)據(jù)文件的安全性,也就是權(quán)限設(shè)置問(wèn)題。因此MySQL數(shù)據(jù)庫(kù)安全配置是至關(guān)重要的。
    2011-03-03
  • mysql自增ID起始值修改方法

    mysql自增ID起始值修改方法

    本文介紹mysql自增ID的起始值修改與設(shè)置方法
    2013-11-11
  • mysql 無(wú)法連接問(wèn)題的定位和修復(fù)過(guò)程分享

    mysql 無(wú)法連接問(wèn)題的定位和修復(fù)過(guò)程分享

    開發(fā)的一款網(wǎng)站防護(hù)產(chǎn)品中出現(xiàn)了一個(gè)客戶端上安裝后Mysql每隔一段時(shí)間就出現(xiàn)問(wèn)題,這個(gè)問(wèn)題是客戶反饋的,所以需要去復(fù)現(xiàn)和定位
    2013-03-03
  • mysql事務(wù)隔離級(jí)別詳情

    mysql事務(wù)隔離級(jí)別詳情

    這篇文章主要介紹了mysql事務(wù)隔離級(jí)別,文章圍繞mysql事務(wù)隔離的相關(guān)資料詳細(xì)展開文章重點(diǎn),需要的小伙伴可以參考一下,希望對(duì)你有所幫助
    2021-10-10
  • Win7、WinXP下MySql安裝出錯(cuò)完全卸載的方法步驟

    Win7、WinXP下MySql安裝出錯(cuò)完全卸載的方法步驟

    這篇文章主要介紹了Win7、WinXP下MySql安裝出錯(cuò)完全卸載的方法步驟,本文給出詳細(xì)的操作步驟,按本文方法清理后,重新安裝,應(yīng)該就不會(huì)有錯(cuò)誤了,需要的朋友可以參考下
    2015-06-06
  • 解決ERROR?1129?(HY000):?Host?‘xxx‘?is?blocked?because?of?many問(wèn)題

    解決ERROR?1129?(HY000):?Host?‘xxx‘?is?blocked?because?

    這篇文章主要介紹了解決ERROR?1129?(HY000):?Host?‘xxx‘?is?blocked?because?of?many問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • MySQL深分頁(yè),limit 100000,10優(yōu)化方式

    MySQL深分頁(yè),limit 100000,10優(yōu)化方式

    MySQL中深分頁(yè)查詢因需掃描大量數(shù)據(jù)行導(dǎo)致效率低下,優(yōu)化方法包括子查詢優(yōu)化、延遲關(guān)聯(lián)、標(biāo)簽記錄法和使用between...and...等,通過(guò)減少回表次數(shù)和范圍掃描提升查詢性能,覆蓋索引幫助減少搜索次數(shù),提升性能
    2024-10-10
  • mysql報(bào)錯(cuò)Duplicate entry ‘xxx‘ for key ‘字段名‘的解決

    mysql報(bào)錯(cuò)Duplicate entry ‘xxx‘ for key&nbs

    有時(shí)候?qū)Ρ磉M(jìn)行操作,例如加唯一鍵,或者插入數(shù)據(jù),會(huì)報(bào)錯(cuò),本文就來(lái)介紹一下mysql報(bào)錯(cuò)Duplicate entry ‘xxx‘ for key ‘字段名‘的解決方法,感興趣的可以了解一下
    2023-10-10

最新評(píng)論