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;

  2. 合并多表UNION可以用于合并两个以上的查询结果集,每个查询之间用 UNION连接。

    SELECT column_name(s) FROM table1
    UNION
    SELECT column_name(s) FROM table2
    UNION
    SELECT column_name(s) FROM table3;

  3. 指定排序UNION的结果集默认不排序。如果你想要对合并后的结果进行排序,需要使用 ORDER BY子句,并且只能放在所有 UNION操作的最后。

    (SELECT column_name(s) FROM table1)
    UNION
    (SELECT column_name(s) FROM table2)
    ORDER BY column_name;

  4. 使用别名 : 可以为 UNION中的每个查询指定别名,使结果集更加清晰。

    (SELECT column_name AS alias_name FROM table1) AS t1
    UNION
    (SELECT column_name AS alias_name FROM table2) AS t2;

  5. 与子查询结合使用UNION可以与子查询结合使用,子查询可以是更复杂的查询。

    (SELECT * FROM table1 WHERE condition1)
    UNION
    (SELECT * FROM (SELECT * FROM table2) AS subquery WHERE condition2);

  6. **使用 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 --

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

-- END --

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

本文由mdnice多平台发布

相关推荐
郝学胜-神的一滴15 小时前
Linux下创建线程:从入门到实践
linux·服务器·开发语言·c++·程序人生·软件工程
yaoh.wang17 小时前
力扣(LeetCode) 67: 二进制求和 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
小年糕是糕手17 小时前
【C++】string类(二)
开发语言·数据结构·c++·程序人生·算法·leetcode·数字货币
yaoh.wang17 小时前
力扣(LeetCode) 58: 最后一个单词的长度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
郝学胜-神的一滴17 小时前
使用Qt OpenGL开发俄罗斯方块:从零到一实现经典游戏
c++·qt·程序人生·游戏·设计模式·系统架构·图形渲染
玄斎1 天前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
CeshirenTester1 天前
Playwright元素定位详解:8种定位策略实战指南
人工智能·功能测试·程序人生·单元测试·自动化
yaoh.wang2 天前
力扣(LeetCode) 28: 找出字符串中第一个匹配项的下标 - 解法思
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
yaoh.wang2 天前
力扣(LeetCode) 35: 搜索插入位置 - 解法思路
程序人生·算法·leetcode·面试·职场和发展·跳槽·二分搜索
小哈里2 天前
【情感】程序人生之理想主义的情感希冀(个人背景、兴趣爱好、爱情观、理想的另一半、期待什么样的生活等)
程序人生·职场和发展·生活·感情·家与生活