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)
相关推荐
weelinking5 小时前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
2301_803934615 小时前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
秋96 小时前
windows中安装redis
数据库·redis·缓存
Cosolar6 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap6 小时前
IO多路转接之poll
服务器·开发语言·数据库·c++
SeaTunnel7 小时前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步
凯瑟琳.奥古斯特7 小时前
数据冗余与规范化的本质[数据库原理]
开发语言·数据库·职场和发展
_ku_ku_8 小时前
数据库系统原理 · SQL 数据定义、更新及数据库编程 · 自学总结
数据库·oracle
Mortalbreeze8 小时前
深度理解文件系统 ---- 从磁盘存储到内核存储
大数据·linux·数据库
2301_803934618 小时前
MySQL 字段类型选择规范指南
jvm·数据库·python