SQL union

MySQL版本5.6.16
union的使用场景:没有发现很合适的场景,就用下之前的例子,理清union的用法就好了。。最佳的union使用场景还是通过union来实现 full join
(在网上查看好多union的例子,有2种使用场景:1.同一个表的两种不同的where条件union;2.两个不同的表有相似的内容,选取相同的列进行union。但这2种情况在实际情况上都比较少,回想一下在实际项目中用union来实现业务的情况好像还真的木有呢)
这里写图片描述
(水之队,又加入了一个成员,也叫小珩,即一个小组内出现了成员名字相同的情况)

union用法

  1. union

目的:查询出members表中group_id = 1和group_id为null的成员:

select m.member_name from members m where m.group_id = 1
union
select m.member_name from members m where m.group_id is null;

结果:
这里写图片描述
分析:将上面查询的结果和下面的查询结果组合在了一起。会发现一个问题,“小珩”这条数据只展示了一遍,但是我们有两个小珩呀。所以union会对查到的结果进行去重处理

  1. union all

目的:解决union遇到的问题,将所有查到的结果查询出来:

select m.member_name from members m where m.group_id = 1
union all
select m.member_name from members m where m.group_id is null;

结果:
这里写图片描述

分析:可以看到“小珩”的数据展示了两次,即union all会将查到的结果直接全部展示出来

总结:join/union的感性认识&区别

  • join联结的两个表,是通过匹配两个表中相同字段的相同的值,得到的结果集。可以认为是结果集的列拓宽了。join是使得查询的内容更详细了。
  • union是取将两个结果集的并集,但两个结果集所拥有的列数是一样、列的顺序也一样、字段类型相同或相似(DBMS认为的相似),才能union并展示在一起。可以认为是结果集的行数多了。union是使得查询的结果更多了。
### SQL UNION 的基本概念 SQL `UNION` 运算符用于组合两个或多个 SELECT 语句的结果集。需要注意的是,每个 SELECT 语句中的列数必须相同,并且相应的列应具有相似的数据类型。 #### 基本语法结构 ```sql SELECT column_name(s) FROM table1 UNION SELECT column_name(s) FROM table2; ``` 此语法可以扩展到更多的表和子查询[^1]。 ### 使用 GROUP BY 和 HAVING 子句增强 UNION 查询 当需要对联合后的数据进一步分组并筛选时,可以在最终的 `UNION ALL` 结果上应用 `GROUP BY` 及其伴随的过滤条件 `HAVING`: ```sql WITH combined_data AS ( SELECT id, name, value FROM tableA UNION ALL SELECT id, name, value FROM tableB ) SELECT id, SUM(value) as total_value FROM combined_data WHERE total_value > 100 -- 此处为示例条件 GROUP BY id HAVING COUNT(*) > 1; -- 应用聚合函数后进行过滤 ``` 这段代码展示了如何先通过 `UNION ALL` 合并来自不同表格的数据流,再利用 CTE (Common Table Expression) 对整个结果集合做更复杂的处理。 ### 实际案例分析 假设存在两张销售记录表 sales_january 和 sales_february ,每张表都有相同的字段 structure `(id INT, product VARCHAR(50), amount DECIMAL)` 。为了获取这两个月份内所有产品的总销售额,可采用如下方式实现: ```sql -- 不同月份销售情况汇总 SELECT 'January' month, product, sum(amount) monthly_sales FROM sales_january GROUP BY product UNION ALL SELECT 'February', product, sum(amount) FROM sales_february GROUP BY product; -- 如果希望去除重复项,则使用 UNION 而不是 UNION ALL ``` 这里选择了 `UNION ALL` 来保留所有的行,即使某些产品在这两个月都出现了也不会被去重。如果确实不需要重复的产品条目,那么应该改用普通的 `UNION` 关键字来代替。 ### 性能考量与优化建议 对于大规模数据集而言,在设计涉及 `UNION` 或者 `UNION ALL` 的查询之前应当考虑性能影响因素。通常情况下,`UNION ALL` 比起单纯的 `UNION` 更加高效因为它不会尝试消除重复记录。因此除非业务逻辑严格要求唯一性,否则推荐优先选用 `UNION ALL` 提升效率。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值