Mysql - 是否可以对前一行值进行累积求和

时间:2013-02-19 04:19:58

标签: mysql

我已经尝试了一段时间但没有成功。

我的数据库是这样的

-----------------------------------------------------
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

例如:我在2013年1月12日获得crespo计数为1,2013年1月13日获得2,2013年1月14日获得1

现在我想得到设备的运行数,即将前一天的值添加到当天下载并继续直到结束。

例如:crespo计数应于2013年1月12日1日,2013年1月13日3日和2013年1月14日4日

这可以在mysql中使用吗?

2 个答案:

答案 0 :(得分:1)

我认为这就是你要找的东西:

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   

答案 1 :(得分:0)

试试这个,
您需要额外变量来检查计数

fiddle example