• 跳至主要導覽
  • 跳至主要內容
  • 跳至主要資訊欄
Office 指南

Office 指南

辦公室工作實用教學

  • Excel
  • Word
  • PowerPoint
  • Windows
  • PowerShell
  • R

MySQL/MariaDB 資料庫 UNION 結合多個查詢結果教學與範例

介紹如何使用 MySQL/MariaDB 資料庫的 UNION 結合多個查詢結果,並自動刪除重複的資料。

建立示範用資料

在說明 UNION 的用法之前,我們先建立兩張示範用的資料表,第一張 engineers 資料表用來儲存工程師的人員資料:

-- 建立 engineers 資料表
CREATE TABLE engineers (
  id INT NOT NULL AUTO_INCREMENT, -- 序號,整數、非空、自動遞增
  name VARCHAR(255),              -- 名字,可變長度的文字
  PRIMARY KEY (id)                -- 主鍵
);
-- 插入多筆資料至 engineers 資料表
INSERT INTO engineers (name) VALUES ("Bond"), ("Cole"), ("Dana");
-- 查看 engineers 資料表內所有資料
SELECT * FROM engineers;
+----+------+
| id | name |
+----+------+
|  1 | Bond |
|  2 | Cole |
|  3 | Dana |
+----+------+

第二張 salespeople 資料表用來儲存銷售員的人員資料:

-- 建立 salespeople 資料表
CREATE TABLE salespeople (
  id INT NOT NULL AUTO_INCREMENT, -- 序號,整數、非空、自動遞增
  name VARCHAR(255),              -- 名字,可變長度的文字
  PRIMARY KEY (id)                -- 主鍵
);
-- 插入多筆資料至 salespeople 資料表
INSERT INTO salespeople (name) VALUES ("Cole"), ("Dana"), ("Lily");
-- 查看 salespeople 資料表內所有資料
SELECT * FROM salespeople;
+----+------+
| id | name |
+----+------+
|  1 | Cole |
|  2 | Dana |
|  3 | Lily |
+----+------+

UNION 結合資料表

UNION 可以合併多個 SELECT 查詢結果,並自動刪除重複的資料:

-- 合併 engineers 與 salespeople 的 name 資料
(SELECT name FROM engineers) UNION (SELECT name FROM salespeople);
+------+
| name |
+------+
| Bond |
| Cole |
| Dana |
| Lily |
+------+

UNION 會自動將重複的資料刪除,若要保留重複的資料,可以改用 UNION ALL:

-- 合併 engineers 與 salespeople 的 name 資料(保留重複資料)
(SELECT name FROM engineers) UNION ALL (SELECT name FROM salespeople);
+------+
| name |
+------+
| Bond |
| Cole |
| Dana |
| Cole |
| Dana |
| Lily |
+------+

若是查詢的結果包含多個欄位,則會比對每一欄位的資料,只有完全一樣的資料列才會被刪除:

-- 合併多欄位的查詢結果
(SELECT * FROM engineers) UNION (SELECT * FROM salespeople);
+----+------+
| id | name |
+----+------+
|  1 | Bond |
|  2 | Cole |
|  3 | Dana |
|  1 | Cole |
|  2 | Dana |
|  3 | Lily |
+----+------+

分類:資料庫 標籤:MySQL/MariaDB

讀者互動方式

發佈留言 取消回覆

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *

主要資訊欄

搜尋

近期文章

  • C++ 語言使用 Crypto++ 實作 RSA 數位簽章教學與範例
  • C++ 語言使用 Crypto++ 實作 RSA-OAEP 搭配 SHA256 加密教學與範例
  • C++ 語言使用 Crypto++ 實作 AES 加密、解密、認證加密教學與範例
  • C++ 語言使用 Crypto++ 實作 MD5、SHA1、SHA2、BLAKE2 雜湊教學與範例
  • Ubuntu Linux 安裝、使用 Crypto++ 加密函式庫教學與範例
  • C 語言使用 OpenSSL 實作橢圓曲線 ECDH 金鑰交換教學與範例
  • Python 以 eciespy 實作 ECC 非對稱式加密方法教學與範例
  • C 語言使用 OpenSSL 實作 PBKDF2 教學與範例

推薦網站

  • Udemy 線上教學課程
  • Coursera 線上教學課程

關注本站

  • 電子郵件
  • Facebook

公益

  • 家扶基金會
  • 台灣世界展望會
  • Yahoo 奇摩公益
  • igiving 公益網
  • 兒福聯盟

Copyright © 2021 · Office Guide