首页  >  问答  >  正文

创建一个在MySQL中进行累积求和的列

<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粉670838735P粉670838735448 天前489

全部回复(2)我来回复

  • P粉245276769

    P粉2452767692023-08-23 09:47:13

    使用相关查询:


    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不支持)可能会有更大的影响

    回复
    0
  • P粉006540600

    P粉0065406002023-08-23 00:13:27

    如果性能是一个问题,你可以使用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;

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

    回复
    0
  • 取消回复