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)
相关推荐
nongcunqq1 小时前
abap 操作 excel
java·数据库·excel
rain bye bye1 小时前
calibre LVS 跑不起来 就将setup 的LVS Option connect下的 connect all nets by name 打开。
服务器·数据库·lvs
阿里云大数据AI技术3 小时前
云栖实录|MaxCompute全新升级:AI时代的原生数据仓库
大数据·数据库·云原生
不剪发的Tony老师3 小时前
Valentina Studio:一款跨平台的数据库管理工具
数据库·sql
weixin_307779133 小时前
在 Microsoft Azure 上部署 ClickHouse 数据仓库:托管服务与自行部署的全面指南
开发语言·数据库·数据仓库·云计算·azure
六元七角八分4 小时前
pom.xml
xml·数据库
虚行4 小时前
Mysql 数据同步中间件 对比
数据库·mysql·中间件
奥尔特星云大使4 小时前
mysql读写分离中间件Atlas安装部署及使用
数据库·mysql·中间件·读写分离·atlas
牛马baby4 小时前
【mysql】in 用到索引了吗?
数据库·mysql·in
杀气丶4 小时前
L2JBR - 修复数据库编码为UTF8
数据库·sql·oracle