吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1719|回复: 37
收起左侧

[求助] SQL 查询结果合并

[复制链接]
7R903 发表于 2022-7-11 20:00
各位大佬,请教一个问题

附件有一张表,左右各是一个查询结果集,怎么样拼出最下方的结果/


我尝试用union all,但会产生多条记录


两个结果集出自一张表tb,右边多加了个条件
相当于:

select 用户,sum(数量) from tb group by 用户
select 用户,sum(数量) from tb where status<>'A' group by 用户
image.png

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
WAITME66 + 1 + 1 热心回复!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

Bakura 发表于 2022-7-11 20:13
不是很懂这个,不过下面那个结果,应该是视图吧?要创建视图。
 楼主| 7R903 发表于 2022-7-11 20:15
Bakura 发表于 2022-7-11 20:13
不是很懂这个,不过下面那个结果,应该是视图吧?要创建视图。

不用,单纯的查询
摸鱼怪 发表于 2022-7-11 20:22
摸鱼怪 发表于 2022-7-11 20:24
或者子查询?
 楼主| 7R903 发表于 2022-7-11 20:24

有想过子查询,但是没什么思路
wxk0248 发表于 2022-7-11 20:26
把all去掉
select 用户,sum(数量) from tb group by 用户
union
select 用户,sum(数量) from tb where status<>'A' group by 用户
或者
select distinct  a.* from
(
select 用户,sum(数量) from tb group by 用户
union all
select 用户,sum(数量) from tb where status<>'A' group by 用户
) a
cshadow 发表于 2022-7-11 20:38
select A.用户,数量1, 数量2
from【select 用户,sum(数量)  as 数量1  from tb group by 用户】   这个 做表A
【select 用户,sum(数量) as 数量2  from tb where status<>'A' group by 用户】 这个 做表B    条件  A.用户 = B.用户
wapj3076 发表于 2022-7-11 21:10
太高深了,看不懂!
XiaoXin10 发表于 2022-7-11 21:12
union all和union都是可以有效进行两个结果合并整理,Union在整理的过程中会将一些重复的选项筛选,并且针对所产生的结果进行排列顺序之后运算。通常来说,在很多的数据整理当中,都很少会出现重复记录。Union all操作过程中会针对两个结果直接合并之后就会返回
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 09:44

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表