创建一个在MySQL中进行累积求和的列
P粉670838735
P粉670838735 2023-08-22 11:26:08
0
2
535
<p>我有一个看起来像这样的表:</p> <pre class="brush:php;toolbar:false;">id count 1 100 2 50 3 10</pre> <p>我想要添加一个名为cumulative_sum的新列,所以表看起来像这样:</p> <pre class="brush:php;toolbar:false;">id count cumulative_sum 1 100 100 2 50 150 3 10 160</pre> <p>有没有一条MySQL更新语句可以轻松实现这个?最好的方法是什么?</p>
P粉670838735
P粉670838735

全部回复(2)
P粉245276769

使用相关查询:


SELECT t.id,
         t.count,
         (SELECT SUM(x.count)
            FROM TABLE x
           WHERE x.id <= t.id) AS cumulative_sum
    FROM TABLE t
ORDER BY t.id

使用MySQL变量:


SELECT t.id,
         t.count,
         @running_total := @running_total + t.count AS cumulative_sum
    FROM TABLE t
    JOIN (SELECT @running_total := 0) r
ORDER BY t.id

注意:

  • JOIN (SELECT @running_total := 0) r是一个交叉连接,允许在不需要单独的SET命令的情况下声明变量。
  • MySQL要求为任何子查询/派生表/内联视图提供表别名r

注意事项:

  • 仅适用于MySQL,不可移植到其他数据库
  • ORDER BY非常重要,它确保顺序与原始问题匹配,并且对于更复杂的变量使用(例如:伪ROW_NUMBER/RANK功能,MySQL不支持)可能会有更大的影响
P粉006540600

如果性能是一个问题,你可以使用MySQL变量:

set @csum := 0;
update YourTable
set cumulative_sum = (@csum := @csum + count)
order by id;

或者,你可以移除cumulative_sum列,并在每个查询中计算它:

set @csum := 0;
select id, count, (@csum := @csum + count) as cumulative_sum
from YourTable
order by id;

这样以一种连续的方式计算累积和 :)

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板