Oracle 逐行累计求和函数 sum() over()

文章目录

1 概述

1. 需求简述:每列 '追加' 所有前列的值
   column   =>   new column
   v1            v1
   v2            v1 + v2
   v3            v1 + v2 + v3
   ...           ...
   vn            v1 + v2 + v3 + ... + vn   
2. 解决办法
   sum(1) over(order by2)
   sum(1) over(partition by2 order by3) -- 先按 列2 分组

 
 

2 示例

with student_info as (
  select 1 sno, 'a' sname, 80 score from dual union all
  select 2 sno, 'b' sname, 100 score from dual union all
  select 3 sno, 'c' sname, 120 score from dual union all
  select 4 sno, 'a' sname, 100 score from dual union all
  select 5 sno, 'b' sname, 200 score from dual
)
select si.sno 学号,
       si.sname 姓名,
       si.score 成绩,
       sum(si.score) over(order by si.sno) 累计成绩1,
       sum(si.score) over(partition by si.sname order by si.sno) 累计成绩2
  from student_info si
 order by si.sno;

 
 

查询结果:

学号		姓名		成绩		累计成绩1	累计成绩2
1		a		80		80			80       -- a1
2		b		100		180			100            --- b1         
3		c		120		300			120 
4		a		100		400			180      -- a2
5		b		200		600			300            --- b2

 
 

3 扩展

3.1 最大值和最小值

-- 聚合函数 + over()
with student_info as (
  select 1 sno, 'a' sname, 80 score from dual union all
  select 2 sno, 'b' sname, 100 score from dual union all
  select 3 sno, 'c' sname, 120 score from dual
)
select si.sno 学号,
       si.sname 姓名,
       si.score 成绩,
       max(si.score) over(order by si.sno) 最大值,
       min(si.score) over(order by si.sno) 最小值,
       avg(si.score) over(order by si.sno) 平均值
  from student_info si;

 
 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值