Welcome 微信登录

首页 / 数据库 / MySQL / Oracle 累计求和

//将当前行某列的值与前面所有行的此列值相加,即累计求和:  
with t as(  
     select 1 val from dual union all  
     select 3 from dual union all  
     select 5 from dual union all  
     select 7 from dual union all  
     select 9 from dual)  
select val,  
       sum(val)  
       over (order by rownum rows between unbounded preceding and current row)  
       sum_val  
from t  
group by rownum,val  
order by rownum;  
       VAL    SUM_VAL  
---------- ----------  
         1          1  
         3          4  
         5          9  
         7         16  
         9         25  
//解析:  
//sum(val)计算累积和;  
//order by rownum 按照伪列rownum对查询的记录排序;  
//between unbounded preceding and current row:定义了窗口的起点和终点;  
//unbounded preceding:窗口的起点包括读取到的所有行;  
//current row:窗口的终点是当前行,默认值,可以省略;  Oracle 通过rownum实现分页Oracle 数据字典表之:DBA_TABLES相关资讯      Oracle教程 
  • Oracle中纯数字的varchar2类型和  (07/29/2015 07:20:43)
  • Oracle教程:Oracle中查看DBLink密  (07/29/2015 07:16:55)
  • [Oracle] SQL*Loader 详细使用教程  (08/11/2013 21:30:36)
  • Oracle教程:Oracle中kill死锁进程  (07/29/2015 07:18:28)
  • Oracle教程:ORA-25153 临时表空间  (07/29/2015 07:13:37)
  • Oracle教程之管理安全和资源  (04/08/2013 11:39:32)
本文评论 查看全部评论 (0)
表情: 姓名: 字数