组合查询(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
去重 自动对合并后的结果集进行去重 直接合并所有结果,不进行去重
性能 较慢 更快
适用场景 需要合并结果并确保无重复数据时 确定无重复数据,或需要保留重复数据时
相关推荐
weixin_4597539421 分钟前
golang如何实现Trace上下文传播_golang Trace上下文传播实现思路
jvm·数据库·python
weixin_4440129330 分钟前
PHP 中逻辑或(--)运算符的正确使用与条件逻辑重构指南
jvm·数据库·python
iAm_Ike7 小时前
Go 中自定义类型与基础类型间的显式类型转换详解
jvm·数据库·python
iuvtsrt7 小时前
Golang怎么实现方法集与接口的匹配_Golang如何理解值类型和指针类型实现接口的区别【详解】
jvm·数据库·python
tongluowan0078 小时前
MySQL中列数量及长度
数据库·mysql
-liming-8 小时前
单片机设计_串口调试工具
数据库·单片机·mongodb
鹿角片ljp8 小时前
从告警检测到智能研判:SQL 注入研判模型的设计与实践
数据库·sql
小新同学^O^10 小时前
简单学习 --> Spring事务
数据库·学习·spring
前进的李工10 小时前
MySQL慢查询日志优化实战
数据库·mysql·性能优化
KaMeidebaby10 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博