从单个表计算运行总数



我想根据以前的数据获得当前的总和。示例:

*******************************************
*    Current balance    *    Total sum    *
*******************************************
     8500                    8500
     -500.50                 7999.50
     380.90                  8380.40
     -5500                   2880.40

除了使用简单的SUM()SELECT SUM(data_sum) FROM table ...)之外,我没有任何自己的代码可以显示,因为我不知道如何实现这一点。

我发现了很多类似的问题,但我不明白答案(示例1)。

这是我的桌子:

`id` int(11) NOT NULL AUTO_INCREMENT,
`id_user` int(11) DEFAULT NULL,
`id_account` int(11) DEFAULT NULL,
`id_account_to` int(11) DEFAULT NULL,
`id_store` int(11) DEFAULT NULL,
`id_image` int(11) DEFAULT NULL,
`data_name` varchar(45) NOT NULL,
`data_name_short` varchar(45) NOT NULL,
`data_sum` decimal(10,2) DEFAULT NULL,
`data_file` text NOT NULL,
`data_note` text NOT NULL,
`is_transfered` tinyint(4) DEFAULT NULL,
`add_time` tinyint(4) DEFAULT NULL,
`datetime_payed` datetime NOT NULL,
`datetime_added` datetime NOT NULL,
`datetime_edited` datetime NOT NULL

现在我的问题是:如何让SQL查询像第一个例子中那样,根据上表计算运行总数?

您可以使用变量:

select data_sum, (@s := @s + data_sum) as cume_sum
from table t cross join
     (select @s := 0) params
order by ??;

当进行累积求和时,应该按某个值(通常是时间列)排序。

相关内容

  • 没有找到相关文章

最新更新