0

我有一个foreach打印数据库中的所有数据的设备。数据如下所示:

data_sum
63
78
25
35

对于循环中的每一行,我想添加总和,如下所示:

data_sum
63
141
166
201

我曾尝试使用此 SQL 查询:

SET @csum := 63;
SELECT id_account, data_sum, is_expense, (@csum := @csum + data_sum) AS cumulative_sum FROM economy_events
WHERE id_account = '4'
AND is_expense = '1'

但我只有SQLSTATE[HY000]: General error在尝试时才会得到。这是我第一次尝试使用这种方法。我做错了什么?

提前致谢。

4

1 回答 1

2

当直接从您的问题粘贴时,您的查询在 MySQL(至少 5.1、5.5 和 5.6)中有效。

看到这个 SQLfiddle:http ://sqlfiddle.com/#!8/53241/1/1

但是,您应该将 @csum 初始化为 0 以重现您想要的输出。此外,为了使累积总和有意义,您需要在 order by查询中添加一个子句。

如果您从某种编程语言运行查询,则问题可能是续行有问题,或者查询由两个语句组成。

您可以尝试将查询重写为

SELECT id_account, data_sum, is_expense,
       (@csum := @csum + data_sum) AS cumulative_sum
FROM economy_events, (SELECT @csum := 0) AS csums
WHERE id_account = '4'
AND is_expense = '1'
于 2013-01-19T11:18:32.137 回答