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)
相关推荐
a9511416422 分钟前
SQL触发器实现自动生成流水号_配合序列对象实现递增逻辑
jvm·数据库·python
BduL OWED5 分钟前
SQL进阶——JOIN操作详解
数据库·sql·oracle
解救女汉子13 分钟前
mysql如何配置元数据锁超时_mysql lock_wait_timeout设置
jvm·数据库·python
下次再写19 分钟前
Java互联网大厂面试技术问答实战:涵盖Java SE、Spring Boot、微服务及多场景应用
java·数据库·缓存·面试·springboot·microservices·技术问答
白豆五23 分钟前
Redis高级(持久化机制、主从集群、哨兵、分片集群)
数据库·redis·缓存
woniu_buhui_fei24 分钟前
Redis知识整理一
数据库·redis·缓存
214396536 分钟前
SQL注入防御技术方案_基于正则表达式的输入清洗
jvm·数据库·python
2401_8323655244 分钟前
SQL窗口函数与递归查询的区别_如何根据场景选择
jvm·数据库·python
u01091476044 分钟前
c++如何处理文件路径中由于不规范的连续斜杠导致的路径解析错误【避坑】
jvm·数据库·python
2301_796588501 小时前
PHP源码开发用二手硬件划算吗_性价比与稳定性权衡【操作】
jvm·数据库·python