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;

返回结果:

相关推荐
l1t2 分钟前
修改一个触发PostgreSQL 17.2 bug的SQL
sql·postgresql·bug
运维行者_5 分钟前
不同规模企业如何选 OPM?参考局域网管理软件与 cpu 温度监控适配指南
大数据·运维·服务器·网络·数据库·postgresql·snmp
soumns丶涛6 分钟前
ESP32学习(1) - 点亮第一个LED
学习
冰冰菜的扣jio11 分钟前
MySQL高性能优化合集
数据库·mysql
weixin_4046793112 分钟前
vscode 配置cpp调试环境
数据库·ide·vscode·编辑器
TG:@yunlaoda360 云老大14 分钟前
华为云国际站代理商GaussDB主要有什么作用呢?
服务器·数据库·华为云·gaussdb
全栈陈序员16 分钟前
请描述下你对 Vue 生命周期的理解?在 `created` 和 `mounted` 中请求数据有什么区别?
前端·javascript·vue.js·学习·前端框架
代码游侠17 分钟前
应用——UDP Socket 编程笔记
linux·运维·网络·笔记·网络协议·学习·udp
ohoy18 分钟前
业务数据聚合分析 xxl-job定时任务
数据库·oracle
是阿威啊21 分钟前
【第六站】测试本地项目连接虚拟机上的大数据集群
大数据·linux·hive·hadoop·spark·yarn