组合查询(UNION)

目录

UNION

[UNION ALL](#UNION ALL)

区别


定义

组合查询指将两个或多个SELECT语句的结果集合并为一个结果集返回。

适用场景

从不同表中返回结构相同的数据。

对同一个表执行多个查询,并将结果合并为一个结果集返回。

UNION

语法:在多条独立的SELECT语句之间,用关键字UNION连接。

要求:查询所有来自北京市和上海市的客户信息,合并为一个结果集

sql 复制代码
SELECT cust_id, cust_name, cust_address
FROM customers
WHERE cust_address LIKE '北京市%'
UNION
SELECT cust_id, cust_name, cust_address
FROM customers
WHERE cust_address LIKE '上海市%';

等价的OR写法:

sql 复制代码
SELECT cust_id, cust_name, cust_address
FROM customers
WHERE cust_address LIKE '北京市%' 
   OR cust_address LIKE '上海市%';

OR只适用于同一张表的多条件筛选,UNION作用是合并不同查询的结果集

OR 是条件判断,UNION 是结果合并

UNION的规则是多个被合并的 SELECT 语句,必须返回相同数量的列,并且对应列的数据类型要兼容。字段名可以不同,最终结果集会以第一个SELECT的字段名为准。

要求:现在需要一份完整的联系人列表,既包含客户的电话和邮箱,也包含供应商的电话和地址。

sql 复制代码
SELECT 
    cust_id AS id,
    cust_name AS name,
    cust_phone AS contact_info,
    '客户' AS type
FROM customers
UNION
SELECT 
    vend_id,
    vend_name,
    vend_phone,
    '供应商'
FROM vendors;

UNION ALL

要求:现在需要对比商品的标价(来自 products 表)和实际成交价(来自 orderItems 表)。同一个商品可能有多次成交,需要看到所有的成交记录。

sql 复制代码
SELECT 
    prod_id,
    prod_name,
    prod_price AS price,
    '标价' AS price_type
FROM products
UNION ALL
SELECT 
    oi.prod_id,
    p.prod_name,
    oi.item_price AS price,
    '成交价' AS price_type
FROM orderItems oi
JOIN products p ON oi.prod_id = p.prod_id;

区别

特性 UNION UNION ALL
去重 自动对合并后的结果集进行去重 直接合并所有结果,不进行去重
性能 较慢 更快
适用场景 需要合并结果并确保无重复数据时 确定无重复数据,或需要保留重复数据时
相关推荐
渣波11 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence5 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神5 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据6 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_6 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡6 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧6 天前
Oracle EXPLAIN PLAN
数据库·oracle