Oracle-分析函数(累计求和,排序等)

news/2024/6/23 20:31:14

在Oracle中分析函数又称为开窗函数
分为以下两类:
第一类:是聚合分析函数,主要包含(sum,count,AVG、MAX、MIN等),主要是对内部分组的数值按照要求内部聚合处理;
第二类:是排序分析函数,主要包含(ROW_NUMBER、DENSE_RANK、RANK等),根据不同要求呈现不同的排序方式。
结构函数介绍:

SELECT table.column,
analysis_function() OVER ( [PARTITION BY 字符] [ORDER BY 字段 [rows]] ) as 统计值FROM table;

analysis_function表示分析函数,对应的有sum,count,AVG、MAX、MIN,ROW_NUMBER、DENSE_RANK、RANK等;
OVER:开窗函数名;
partition by :为分组字段;
order by :指定排序字段;
rows:指定数据窗口(即指定分析函数要操作的行数)

聚合分析函数

一、聚合分析函数与聚合函数的不同
聚合分析函数可以在查询语句中,每一组每一行进行聚合,聚合函数只能通过group by 整体聚合。
二、聚合分析函数
聚合分析函数:()中需要填值

--组内计数
count() over(partition by ... order by ...)
--组内最大值
max() over(partition by ... order by ...)
--组内最小值
min() over(partition by ... order by ...)
--组内求和,可计算累计求和
sum() over(partition by ... order by ...)
--组内均值
avg() over(partition by ... order by ...)
--组内的第一个值
first_value() over(partition by ... order by ...)
--组内的最后一个值
last_value() over(partition by ... order by ...)
--Lag函数可以在一次查询中取出当前行的同一字段的前面第N行的数据。
lag() over(partition by ... order by ...)
--Lead函数可以在一次查询中取出当前行的同一字段的后面第N行的值。
lead() over(partition by ... order by ...)

举例:
sum() over(partition by … order by …) 累计求和

select 营销中心,事业部,产品编码,产品名称,品类,年份,月份,,当月指标金额,sum(当月指标金额) over(partition by 营销中心, 事业部,产品编码,产品名称,品类,年份
ORDER BY) 月累计指标,
sum(当月指标金额) over(partition by 营销中心,事业部,产品编码,年份
ORDER BY 产品编码
) 全年指标
FROM   TABLE;

排序分析函数

分为 rank,dense_rank,row_number 三种排序方式。
对应的函数结构如下所示:

rank ( ) over ( [query_partition_clause]order_by_clause )

--rank如果出现两个相同的数据,那么后面的数据就会直接跳过这个排名,比如:当第2名和第3名的利润相同时,rank的结果是1,2,2,4;select d,l,m,rank() over(partition by d order by l)  from aaa;

dense_rank ( ) over ([query_partition_clause] order_by_clause )

--dense_rank则不会跳过这个排名,结果是1,2,2,3
select d,l,m,dense_rank() over(partition by d order by l)  from aaa;

row_number ( ) over ( [query_partition_clause]order_by_clause )

--row_number哪怕是两个数据完全相同,排名也会不一样,结果是1,2,3,4
select d,l,m,row_number() over(partition by d order by l)  from aaa;

通过上面的结构可实现按指定的字段分组排序,对于相同分组字段的结果集进行排序

排序分析函数:()中不填值

--重复排序(1,2,3,4)
row_number() over(partition by ... order by ...)
--重复跳过排序(1,2,2,4)
rank() over(partition by ... order by ...)
--重复不跳过排序(1,2,2,3)
dense_rank() over(partition by ... order by ...)

https://www.xjx100.cn/news/3091632.html

相关文章

【python学习】基础篇-常用函数-sorted() 对可迭代对象进行排序

sorted()函数是Python中的内置函数,用于对可迭代对象进行排序操作。 它会返回一个新的已排序的列表,而不会修改原始的可迭代对象。 sorted()函数的基本语法如下: sorted(iterable, keyNone, reverseFalse)参数说明: iterable:表…

python盘符及路径获取

python盘符及路径获取: 参考: https://pythonjishu.com/rpszkrzoctrpkgq/ https://blog.51cto.com/u_16213346/7272017 https://blog.csdn.net/Java_ZZZZZ/article/details/130846038 http://www.mobiletrain.org/about/BBS/142777.html https://pythonj…

美国 地区 苹果 Apple ID获取

1、先进入苹果Apple ID官网,然后选择“创建你的Apple ID”!,注册一个新的Apple ID。 2、Apple ID使用qq.com多数会报 “目前无法完成你的请求” ,得登录,注册一个网易邮箱,或者hao123邮箱大全,选…

ADB安装及使用介绍

一、ADB简介 1、什么是adb ADB 全称为 Android Debug Bridge,起到调试桥的作用,是一个客户端-服务器端程序。其中客户端是用来操作的电脑,服务端是 Android 设备。 ADB 也是 Android SDK 中的一个工具,可以直接操作管理 Android …

A股风格因子看板 (2023.11 第11期)

该因子看板跟踪A股风格因子,该因子主要解释沪深两市的市场收益、刻画市场风格趋势的系列风格因子,用以分析市场风格切换、组合风格暴露等。 今日为该因子跟踪第11期,指数组合数据截止日2023-10-31,要点如下 近1年A股风格因子收益走…

队列的实现和OJ练习(c语言)

目录 概念 队列的实现 利用结构体存放队列结构 为什么单链表不使用这种方法? 初始化队列 小提示: 队尾入队列 队头出队列 获取队头元素 获取队尾元素 获取队列中有效元素个数 检测队列是否为空 销毁队列 最终代码 循环队列 队列的OJ题 …

gbase 8s 按时间点恢复

如果要实现8S按照时间点进行恢复,需要使用onbar进行备份和恢复,而PSM是又是onbar不可或缺的。 之前我鄙视过onpsm的健壮性,最近反复测试,发现比预想的结果好很多。 onpsm的安装手册详见:GBase 8s PSM简单配置 | GBas…

openCV教程(三)

文章目录 1 车辆统计项目1.1 背景减除1.2 车辆统计2 特征点检测和匹配2.1 harris角点检测2.2 shi-tomasi角点检测2.3 SIFT关键点检测2.4 SURF特征检测2.5 ORB特征检测3 特征匹配3.1 暴力特征匹配3.2 FLANN特征匹配3.3 图像查找3.3.1 单应性矩阵4 模版匹配4.1 模版匹配4.2 匹配多…