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

本文介绍了SQL中的窗口函数使用方法,通过示例展示了如何利用`SUM()`函数配合`OVER()`子句进行列数据的累计求和。在示例中,我们创建了名为`student_info`的表,并演示了按学号顺序和姓名分组的累计成绩计算,同时扩展到最大值、最小值和平均值的计算。这个技巧在数据聚合和分析中非常实用。

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 分组
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鱼丸丶粗面

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值