对重复值求和时如何获得不同的总和?
Posted
技术标签:
【中文标题】对重复值求和时如何获得不同的总和?【英文标题】:How to get distinct sums when summing over repeated values? 【发布时间】:2013-06-03 22:33:50 【问题描述】:我遇到的问题是 Postgres,因为使用具有非唯一值或“销售”的 SUM 会导致非唯一的累积总和或“运行销售”。
这里是查询:
SELECT *,
SUM(Sales) OVER (ORDER BY sales DESC) as running_sales
FROM t;
Here is the output
基本上我希望这张表可以阅读:
4--主板-------- 22----399 5--RAID控制器----22----421有人对我如何做到这一点有任何想法吗?
旁白:如果有人感兴趣,我就是following
【问题讨论】:
【参考方案1】:通过添加id
作为第二个ORDER BY
项,使OVER
子句中的顺序独一无二:
SELECT *,
SUM(Sales) OVER (ORDER BY sales DESC, id) as running_sales
FROM t
ORDER BY sales DESC, id;
按照您的方式,相等的销售额被视为同一 FRAME
中的同行并立即求和。tutorial you were following 不适用于此特定查询。
此外,您可能希望将ORDER BY
添加到查询本身以获得稳定的结果。这很便宜,因为它符合窗口函数的排序顺序。
现在的实现方式,对于简单查询,您通常按照窗口函数的顺序从该查询中获取结果,因为这是最便宜的方式。但是 Postgres 不保证没有ORDER BY
的行的顺序,任意顺序可以在没有警告的情况下改变。
【讨论】:
完美,正是我需要的。谢谢! @user2449623:考虑添加的关于ORDER BY
的信息。以上是关于对重复值求和时如何获得不同的总和?的主要内容,如果未能解决你的问题,请参考以下文章