首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >获取SQL中不同值的总和,并将其显示在记录中

获取SQL中不同值的总和,并将其显示在记录中
EN

Stack Overflow用户
提问于 2018-07-03 07:44:35
回答 1查看 34关注 0票数 1

我有一个SQL表,

代码语言:javascript
复制
 Card_A    | Card_B        | power 
-----------+---------------+-------
 3         | 1             |     9
 2         | 3             |     9
 2         | 3             |     4

我想使用Card_ACard_B的不同值进行sum(power)。当Card_A = 2Card_B = 3时,有两个相同的幂值,分别为9和4。输出应该是,

代码语言:javascript
复制
 Card_A    | Card_B        | power 
-----------+---------------+-------
 3         | 1             |     9
 2         | 3             |     13

这个SQL查询,我试过了,

代码语言:javascript
复制
SELECT DISTINCT card_A, card_B, sum(power) FROM foo ;

我正在使用POstgresql。MySQL解决方案也将被接受。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-03 07:48:05

我认为您需要使用GROUP BY而不是DISTINCT:

代码语言:javascript
复制
SELECT card_a, card_b, SUM(power)
FROM foo
GROUP BY card_a, card_b;

这应该会给你你想要的结果。

DISTINCT将在结果集中找到唯一的记录,但它不会正确地对值进行求和。

使用GROUP BY将创建由您指定的列组成的组(在本例中为card_a和card_b),并且将计算每个组的总和。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51144920

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档