Oracle之开窗函数使用

开窗函数是数据开发面试的必知必会,必须认真对待,上难度:

开窗函数语法格式如下,一共五部分:

sql 复制代码
①函数(a)over(②<partition by b> ③<order by c> ④<windowing_clause> ⑤开窗范围)

1、函数:聚合函数,sum(a)、avg(a)、lag(a,n,null)、lead(a,n,null)、max(a)等

2、分组:partition by b

3、排序:order by c

4、开窗子句:range、rows、Specifying

range:排序字段有相同值时,开窗结果相同

rows:排序字段有相同值时,开窗结果不同

使用开窗子句一定要有排序!!

5、开窗范围:between...and...

sql 复制代码
  between m preceding and n following  --当前行的前m行到当前行的后n行
sql 复制代码
  between unbounded preceding and current row --第一行到当前行

--unbounded:不受控制的,无限的

--preceding:在...之前

--following:在...之后

--current row:当前行

以上为理论,以下为实际案例


1、简单求和

sql 复制代码
sum(a)

2、累加和

sql 复制代码
sum(a)over(order by b)

3、分组求和

sql 复制代码
sum(a)over(partition by c order by b)

4、第一行到当前行分组求和(排序数据重复时,分析函数数据重复)

sql 复制代码
sum(a)over(partition by c order by b range between unbounded 
preceding and current row)

5、第一行到当前行分组求和(排序数据重复时,分析函数数据不重复)

sql 复制代码
sum(a)over (partition by c order by b rows between unbounded preceding and current row)

6、第一行到当前行前一行求和

sql 复制代码
sum(a)over(partition by c order by b range between unbounded
preceding and 1 preceding)

7、第一行到当前行后一行求和

sql 复制代码
sum(a)over(partition by c order by b range between unbounded preceding and 1 following)

8、当前行前80行到当前行求和

sql 复制代码
sum(a)over(partition by c order by b range between 79 preceding and current row)
相关推荐
qq_141826973217 分钟前
python通过curl访问deepseek的API调用案例
java·数据库·python
可喜~可乐35 分钟前
C# SQLite高级功能示例
数据库·sql·sqlite·c#
cooldream20091 小时前
深入理解主从数据库架构与主从复制
数据库·oracle·数据库架构·系统架构师
Eternity......1 小时前
spark MySQL数据库配置
数据库·mysql·spark
Freedom℡1 小时前
使用scp命令拷贝hadoop100中文件到其他虚拟机中
数据库·hadoop·spark
Qdgr_2 小时前
电厂除灰系统优化:时序数据库如何降低粉尘排放
数据库·时序数据库
慧一居士2 小时前
Memcached 服务搭建和集成使用的详细步骤示例
数据库·架构·nosql·memcached
脑子慢且灵2 小时前
MySQL:关系模型的基本理论
数据库·sql·mysql
码农飞哥2 小时前
互联网大厂Java求职面试实战:Spring Boot与微服务场景深度解析
java·数据库·spring boot·安全·微服务·消息队列·互联网医疗
Ai 编码助手2 小时前
可视化+智能补全:用Database Tool重塑数据库工作流
数据库