当前位置: 首页 > news >正文

SQL 基础 | UNION 用法介绍

在SQL中,UNION操作符用于合并两个或多个SELECT语句的结果集,形成一个新的结果集。

使用UNION时,合并的结果集列数必须相同,并且列的数据类型也需要兼容。

默认情况下,UNION会去除重复的行,只保留唯一的行。

以下是UNION的一些常见用法:

  1. 基本用法: 使用 UNION将两个查询的结果集合并,每个查询的列数和类型必须相同。
SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;

例如,合并两个表中所有客户的姓名:

SELECT CustomerName FROM Customers
UNION
SELECT CustomerName FROM Suppliers;
  1. **使用 UNION ALL**: UNION ALLUNION类似,但它不会去除重复的行。如果合并的结果集中存在重复的行, UNION ALL会保留它们。
SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;
  1. 合并多表UNION可以用于合并两个以上的查询结果集,每个查询之间用 UNION连接。
SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2
UNION
SELECT column_name(s) FROM table3;
  1. 指定排序UNION的结果集默认不排序。如果你想要对合并后的结果进行排序,需要使用 ORDER BY子句,并且只能放在所有 UNION操作的最后。
(SELECT column_name(s) FROM table1)
UNION
(SELECT column_name(s) FROM table2)
ORDER BY column_name;
  1. 使用别名: 可以为 UNION中的每个查询指定别名,使结果集更加清晰。
(SELECT column_name AS alias_name FROM table1) AS t1
UNION
(SELECT column_name AS alias_name FROM table2) AS t2;
  1. 与子查询结合使用UNION可以与子查询结合使用,子查询可以是更复杂的查询。
(SELECT * FROM table1 WHERE condition1)
UNION
(SELECT * FROM (SELECT * FROM table2) AS subquery WHERE condition2);
  1. **使用 LIMITOFFSET**: 可以在 UNION操作的每个查询中使用 LIMITOFFSET来控制结果集的行数和偏移量。
(SELECT column_name(s) FROM table1 LIMIT 10
UNION 
(SELECT column_name(s) FROM table2 LIMIT 10 OFFSET 10);

使用UNION时,需要注意以下几点:

  • 所有查询的列数必须相同。
  • 相应列的数据类型必须兼容,不需要完全相同,但是必须是可以比较的。
  • 默认情况下, UNION会自动去除重复的行,如果需要包含重复行,使用 UNION ALL
  • UNION的结果集不能指定列名,列名来自参与 UNION的第一个查询。
  • 对结果集进行排序只能使用一个 ORDER BY子句,并且必须位于所有 UNION操作之后。

UNION是一个非常有用的工具,可以帮助你将来自不同表的数据合并成一个统一的结果集,从而简化数据分析和报告。

-- END --

alt

如果这篇文章为你带来了灵感或启发,就请帮忙点『赞』or『在看』or『转发』吧,感谢!(๑˃̵ᴗ˂̵)

-- END --

alt

如果这篇文章为你带来了灵感或启发,就请帮忙点『赞』or『在看』or『转发』吧,感谢!(๑˃̵ᴗ˂̵)

本文由 mdnice 多平台发布

http://www.lryc.cn/news/341370.html

相关文章:

  • 学习如何使用PyQt5实现notebook功能
  • Python氮氧甲烷乙烷乙烯丙烯气体和固体热力学模型计算
  • 2024-04-30 区块链-以太坊-相关文档
  • 你用过最好用的AI工具有哪些?
  • Amine-PEG-Amine,956496-54-1在生物成像、生物传感器等领域具有广泛的应用
  • 为什么深度学习中减小泛化误差称为“正则化(Regularization)”
  • 【Linux网络编程】2.套接字、网络字节序、IP地址转换函数
  • 代码签名证书的工作原理和申请流程
  • Python中的yield
  • 【Linux】基于 Jenkins+shell 实现更新服务所需文件 -->两种方式:ssh/Ansible
  • 5月4(信息差)
  • 【Spring】1.Spring中IOC与DI全解析
  • vue2迁移到vue3,v-model的调整
  • 【C语言】解决不同场景字符串问题:巧妙运用字符串函数
  • android 如何显示网络地址对应的图片
  • 【项目学习01_2024.05.02_Day04】
  • Android SQLite中的UNIQUE constraint failed错误
  • 嘴尚绝卤味:传承经典,缔造美食新风尚
  • Docker 入门与实践:从零开始构建容器化应用环境
  • C# 用户控件UserControl事件解绑资源释放
  • QT-QTCreator环境配置
  • 最大连续和
  • 分布式系统事务一致性解决方案(基于事务消息)
  • Unity Animation--动画剪辑
  • 如何将 redis 快速部署为 docker 容器?
  • iOS - Undefined symbols: 解决方法
  • 优化理论复习——(三)
  • RK3568笔记二十四:基于Flask的网页监控系统
  • [Django 0-1] Core.Serializers 模块
  • 鸿蒙内核源码分析(用栈方式篇) | 程序运行场地谁提供的