SQL之Running Total,sqlrunningtotal
Running Total是什么意思呢?
假设我们有一张表:TRANS,表明我们有的交易记录,其中有一个column是id,另一个是money(表示该笔交易设计的金额),我们的需求就是如何计算每笔交易以后累积的交易总数。例子如下:
| id | money |
| 1 | 10 |
| 2 | 20 |
| 3 | 15 |
| 4 | 5 |
| 5 | 50 |
如果算每次累积的,就依次是10,30,45,50,100。
一种方式:
SELECT T1.ID, T1.MONEY, SUM(T2.MONEY) RUNNING_TOTAL FROM TRANS T1,TRANS
T2
WHERE T1.ID >= T2.ID
GROUP BY T1.ID, T1.MONEY
ORDER BY T1.ID ASC
ORACLE下,也可以使用OVER:
SELECT ID, SUM(MONEY) OVER (ORDER BY ID) RUNNINGT_TOTAL FROM TRANS
参考资料:
http://www.1keydata.com/sql/sql-running-totals.html
http://www.dba-oracle.com/t_over_analytic_function.htm
http://www.1keydata.com/sql/advanced.html
本站文章为和通数据库网友分享或者投稿,欢迎任何形式的转载,但请务必注明出处.
同时文章内容如有侵犯了您的权益,请联系QQ:970679559,我们会在尽快处理。