首頁  >  問答  >  主體

建立一個在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 天前488

全部回覆(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
  • 取消回覆