mysql 多个sum查询_mysql-将多个SUM查询合并为一个结果

这篇博客介绍了如何在SQL中合并多个SUM查询以计算用户在不同比赛中获得的总积分。通过UNION结合子查询,可以将来自不同比赛的积分汇总到单个结果列中,或者分别显示每个比赛的积分。此外,还提供了在没有数据时返回0的方法以及在用户可能未参加所有比赛时使用FULL JOIN的解决方案。
摘要由CSDN通过智能技术生成

所以…我们有3个与比赛有关的表格,其中DB跟踪他们为每个比赛获得的积分.竞赛1、2和3.每当用户获得成就时,就会为该用户创建一个新行,并附加得分.因此,为了计算用户获得的所有积分,我使用选择总和

SELECT userID,SUM(amount1)as"Contest 1 Points"FROM [Company].[dbo].[Contest1]WHERE userid notin(0,1)GROUP BY userId

ORDER BY userid

因为我还有另外两个比赛,所以我也要查询每个比赛…

SELECT userId,SUM(amount2)/.65AS "Category 2 Points"FROM [Company].[dbo].[Contest2]WHERE dateGiven >=201301AND dateGiven <=201305GROUP BY userId

ORDER BY userid

SELECT userid,SUM(amount3)AS "Category 3 Points"FROM [Company].[dbo].[Contest3]whereuserid notin(1,2)GROUP BY userid

ORDER BY userid

我基本上需要将每个用户从每个竞赛中获得的所有积分加到1个基本上显示结果的列中

USERID,共TOTALS(竞赛1竞赛2竞赛3)

或至少像

USER,共1个竞赛,共2个竞赛,共3个竞赛

到目前为止,我这样做的方法是将每个结果复制/粘贴到excel中,然后我使用VLOOKUP将它们相互匹配,这有点麻烦,并且肯定有一种方法可以在SQL中完成.我对SQL来说还很陌生,我曾尝试加入并使用usig

ON来匹配userid,但是我的语法以及我了解到查询都可以插入其中的方式出了点问题.

解决方法:

<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值