簡體   English   中英

Mysql-是否可以對之前的行值進行累加

[英]Mysql - Is it possible to cumlatively sum the previous row values

我已經嘗試了一段時間,但沒有成功。

我的數據庫是這樣的

-----------------------------------------------------
DEVICE_HASH | DEVICE_NAME | DEVICE_VERISON | DATE
-----------------------------------------------------
122138223823| crespo      | 1.1            | 12/01/13
122138213823| jewell      | 1.2            | 12/01/13
122138223823| crespo      | 1.1            | 13/01/13
122138263823| crespo      | 1.1            | 13/01/13
122138283823| blade       | 1.2            | 13/01/13
122138293823| crespo      | 1.1            | 14/01/13
-----------------------------------------------------

為了獲得每天下載設備的數量,我執行了以下查詢,效果很好。

SELECT DATE_FORMAT(DATE, '%Y-%m-%d') as 'date', DEVICE_NAME as 'device' ,COUNT(*) as 'count' FROM table_name GROUP BY DATE_FORMAT(DATE, '%Y-%m-%d'), DEVICE_NAME

例如:我在12/01/13上的crespo計數為1,在13/01/13上的計數為2,在14/01/13上的計數為1

現在,我想獲取設備的運行計數,即將前一天的值添加到當前一天的下載中,並繼續進行到最后。

例如:crespo計數應在12/01/13時為1,在13/01/13時為3,在14/01/13時為4

在mysql中這可能嗎?

我認為這是您要尋找的:

SELECT
  @runningTotal:=IF(@prevDevice=Device_Name,@runningTotal+cnt,cnt) rt,
  dt, Device_Name, cnt,
  @prevDevice:=Device_Name
FROM (
  SELECT 
    DATE_FORMAT(DATE, '%Y-%m-%d') as dt, 
    DEVICE_NAME ,
    COUNT(*) as cnt
  FROM table_name 
  GROUP BY DATE_FORMAT(DATE, '%Y-%m-%d'), DEVICE_NAME
  ORDER BY DEVICE_NAME, 2
) t
  JOIN (SELECT @runningTotal:=0) r

和示例提琴: http ://sqlfiddle.com/#!2/ e3525/1

產生以下結果:

RT  DT          DEVICE_NAME     CNT 
1   2013-01-13  blade           1   
1   2014-01-13  crespo          1   
3   2013-01-13  crespo          2   
4   2012-01-13  crespo          1   
1   2012-01-13  jewell          1   

嘗試這個 ,
你需要額外的變量來保持計數

小提琴的例子

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM