SQL函数--union all 使用方法及案例

1. 使用方法

在 SQL 中,UNION ALL 操作用于结合两个或更多 SELECT 语句的结果集,包括所有匹配的行,甚至包括重复的行。这与 UNION 不同,因为 UNION 会自动删除重复的行。

满足条件:

1、两个select查询的列的数量必须相同。

2、每个列的数据类型需要相似。

2. 案例一

假设有两个表,table1table2,它们都有相同的列结构(例如,都有 idname 列):

java 复制代码
-- table1 的数据  
id | name  
---|------  
1  | Alice  
2  | Bob  
  
-- table2 的数据  
id | name  
---|------  
3  | Carol  
2  | Bob

如果你想从这两个表中检索所有的行,并保留可能的重复行,你可以使用 UNION ALL

java 复制代码
SELECT id, name FROM table1  
UNION ALL  
SELECT id, name FROM table2;

这将返回以下结果:

java 复制代码
id | name  
---|------  
1  | Alice  
2  | Bob  
3  | Carol  
2  | Bob

3. 案例二

列转换成行

假设我们有一个表sales_summary,它包含了每种产品的销售额汇总:

java 复制代码
CREATE TABLE sales_summary (
    A_sales DOUBLE,
    B_sales DOUBLE,
    C_sales DOUBLE
);

INSERT INTO sales_summary VALUES (250, 200, 300),(100,190,800),(290,290,880),(280,720,990);

现在,我们想要将这个表转换为每行一个产品及其销售额的格式。我们可以使用UNION ALL来实现这一点:

java 复制代码
SELECT 'A' AS product_type, A_sales AS amount FROM sales_summary
UNION ALL
SELECT 'B' AS product_type, B_sales AS amount FROM sales_summary
UNION ALL
SELECT 'C' AS product_type, C_sales AS amount FROM sales_summary;

返回结果:

相关推荐
yaoyouzhong7 分钟前
MySQL 批量插入详解:快速提升大数据导入效率的实战方法
大数据·数据库·mysql
东北甜妹35 分钟前
MySQL主从复制
mysql
NineData39 分钟前
NineData V5.0 产品发布会:让 AI 成为数据管理的驱动力,4月16日!
数据库·人工智能·ai编程
diablobaal1 小时前
云计算学习100天-第102天-Azure入门4
学习·云计算·azure
AI_零食1 小时前
Flutter 框架跨平台鸿蒙开发 - 自定义式按钮设计应用
学习·flutter·ui·华为·harmonyos·鸿蒙
高梦轩1 小时前
PG数据库
数据库·oracle
小陈phd1 小时前
多模态大模型学习笔记(三十)—— 基于YOLO26 Pose实现车牌检测
笔记·学习
云草桑2 小时前
DBA mssql 解决排序规则冲突 QA prod 和开发配置都是一样的服务器排序规则 为啥开发环境的的存储过程需要 加这个COLLATE Chinese_PRC_CI_AS
数据库·dba·mssql
卤炖阑尾炎2 小时前
MySQL 故障排查与生产环境优化实战指南
数据库·mysql
小陈工2 小时前
2026年4月2日技术资讯洞察:数据库融合革命、端侧AI突破与脑机接口产业化
开发语言·前端·数据库·人工智能·python·安全