我的一位同事有一个问题,我正试图帮助他解决。
他有一个 SQL 视图,其中包含以下数据(示例数据):-
Category Value
Cat A 10
Cat A 20
Cat A 30
Cat B 15
Cat B 15
Cat C 10
Cat C 10
他想在视图中添加一列,以保持 Value 列的运行总计。
当类别更改时,此列必须重置运行总计。
所以输出数据必须是这样的:-
Category Value Running
Cat A 10 10
Cat A 20 30
Cat A 30 60
Cat B 15 15
Cat B 15 30
Cat C 10 10
Cat C 10 20
我们可以通过像这样将表格连接到自身来获得运行总数:-
select t1.id, t1.[count], SUM(t2.[count]) as sum
from TableA t1
inner join TableA t2 on t1.id >= t2.id
group by t1.id, t1.[count]
order by t1.id
问题是我们没有 ID 列,当类别更改时,我们将如何指示累计重置?