Oracle分析函数-OLAP函数总结
ORACLE OLAP 函数
最近这个东东用得特别多,总结了一下 。
语法: FUNCTION_NAME(,,...)
OVER()
OLAP函数语法四个部分:
1、function本身 用于对窗口中的数据进行操作;
2、partitioning clause 用于将结果集分区;
3、order by clause 用于对分区中的数据进行排序;
4、windowing clause 用于定义function在其上操作的行的集合,即function所影响的范围。
一、order by对窗口的影响
不含order by的:
SQL> select deptno,sal,sum(sal) over() from emp;
不含order by时,默认的窗口是从结果集的第一行直到末尾。
含order by的:
SQL> select deptno,sal, sum(sal) over(order by deptno) as sumsal from emp;
当含有order by时,默认的窗口是从第一行直到当前分组的最后一行。
二、用于排列的函数
SQL> select empno, deptno, sal,
rank() over (partition by deptno order by sal desc nulls last) as rank,
dense_rank() over (partition by deptno order by sal desc nulls last) as dense_rank,
row_number() over(partition by deptno order by sal desc nulls last) as row_number
from emp;
三、用于合计的函数
SQL> select deptno,sal,
sum(sal) over (partition by deptno) as sumsal,
avg(sal) over (partition by deptno) as avgsal,
count(*) over (partition by deptno) as count,
max(sal) over (partition by deptno) as maxsal
from emp;
四、开窗语句
1、rows窗口: "rows 5 preceding" 适用于任何类型而且可以order by多列。
SQL> select deptno,ename,sal,
sum(sal) over (order by deptno rows 2 preceding) sumsal
from emp;
rows 2 preceding:将当前行和它前面的两行划为一个窗口,因此sum函数就作 用在这三行上面
SQL> select deptno,ename,sal,
sum(sal) over (partition by deptno order by ename rows 2 preceding) sumsal
from emp order by deptno,ename;
加了partiton by分区后之后,rows 2 preceding(窗口)只在当前分区内生效,不会影响分区之外的行。
SQL> select ename,sal,hiredate,
first_value(ename) over (order by hiredate asc rows 5 preceding) first_ename,
first_value(hiredate) over (order by hiredate asc rows 5 preceding) first_hiredate
from emp order by hiredate asc;
order by hiredate asc rows 5 preceding: order by之后,取当前行的前5行+当前行作为窗口(共6行)。
2、"range unbounded preceding"
range unbounded preceding会把当前行之前的所有行都包含进来,但当partition by时:
SQL> select deptno,ename,sal,
sum(sal) over (partition by deptno order by deptno range unbounded preceding) sumsal
from emp;
SQL> select deptno,ename,sal,
sum(sal) over (order by deptno range unbounded preceding) sumsal
from emp;
这SQL句子和下面这SQL是等价的:
select deptno,ename,sal, sum(sal) over (order by deptno) sumsal from emp;
因为order by的默认窗口总是从结果集的第一行开始到它分组的最后一行。
而partiton by的默认窗口总是从分区的第一行开始。
3、range窗口: "range 100 preceding"
这个子句只适用于number和date,而且只能order by一列。
如果over()里asc排列,意思是[number-100,number]这样一个闭区间是它的窗口。
如果over()里desc排列,意思是[number,number+100]这样一个闭区间是它的窗口。
4、窗口总结
1、unbounded preceding:从当前分区的第一行开始,到当前行结束。
2、current row:从当前行开始,也结束于当前行。
3、[numeric expression] preceding:对于rows来说从当前行之前的第[numeric expression]行开始,到当前行结束。对range来说从小于数值表达式的值开始,到当前行结束。
4、[numeric expression] following:与[numeric expression] preceding相反。
转载于:https://www.cnblogs.com/sooner/p/7735154.html
Oracle分析函数-OLAP函数总结相关推荐
- Oracle分析函数一——函数列表
Oracle 分析函数 Oracle 分析函数--函数列表 SUM : 该函数计算组中表达式的累积和 MIN : 在一个组中的数据窗口中查找表达式的最小值 MAX ...
- oracle 四分位函数,Oracle分析函数四——函数RANK,DENSE_RANK,FIRST,LAST…
Oracle 分析函数--函数RANK,DENSE_RANK,FIRST,LAST- RANK 功能描述:根据 ORDER BY 子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置.组内 ...
- Oracle分析函数四——函数RANK,DENSE_RANK,FIRST,LAST…
Oracle分析函数--函数RANK,DENSE_RANK,FIRST,LAST- RANK 功能描述:根据ORDER BY子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置.组内的数据 ...
- oracle分析函数-开窗函数
oracle分析函数 分析函数是什么? 分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计值. ...
- Oracle分析函数七——函数案例
环比 环比就是现在的统计周期和上一个统计周期比较.例如2008年7月份与2008年6月份相比较称其为环比. 环比发展速度是报告期水平与前一时期水平之比,表明现象逐期的发展速度.如计算一年内各月与前一个 ...
- DEV03-GBase 8a MPP Cluster OLAP 函数
GBase 8a MPP Cluster OLAP 函数 一.OLAP函数的基本概念 二.OLAP 函数分类: 三.窗口类 OLAP 函数 (一)概念: (二)语法: (三) 主函数 四.GROUP ...
- Oracle分析函数——函数列表
--------------聚合函数 SUM :该函数计算组中表达式的累积和 MIN :在一个组中的数据窗口中查找表达式的最小值 MAX :在一个组中的数据窗口中查找表达式的最大值 AVG :用于计算 ...
- Oracle分析函数、多维函数和Model函数简要说明,主要针对BI报表统计
以下代码均经过测试,可直接运行 Oracle分析函数.多维函数和Model函数简要说明,主要针对BI报表统计,不一定很全面,但对BI应用场景做了少许说明 --创建一张销售数量表,数据趋势是递增的 CR ...
- oracle 分析函数、GROUPING函数
分析函数 over(Partition by...) 一个超级牛皮的ORACLE特有函数.天天都用ORACLE,用了快2年了.最近才接触到这个功能强大而灵活的函数.真实惭愧啊!oracle的分析函数o ...
最新文章
- 进度条三方库tdqm trange用法
- php向数据库添加数据失败,无法从PHP中的表单向数据库添加数据
- 能玩java游戏oppo按键手机_游戏手机排行榜|OPPO Reno果然不负期待
- prima evb_用Priam设置Cassandra
- LeetCode 992. K 个不同整数的子数组(双指针)
- linux下网络编程设置非阻塞,UNIX网络编程 非阻塞connect的实现
- 如何计算MySQL数据库占用内存
- 11.Linux 高性能服务器编程 --- 定时器
- 判断变量是空_python基础(二):变量的数据类型、常量、操作符、分支、循环、条件判断...
- html5 拖放游戏,HTML5拖放API实现拖放排序的实例代码
- 从零开始设计一个右键菜单组件
- 卷积操作中的group
- 场景文字识别论文阅读
- 命令点亮硬盘灯_【硬盘无法识别怎么办?】
- 数学速算法_小数减法如何学?3种心算速算法,快捷有效,让孩子爱上数学
- 什么是熔断、降级、限流
- 毕业设计-基于深度学习的图像隐写分析
- Linux驱动学习笔记之触摸屏驱动
- html页面执行sql语句,关于在页面上执行sql语句
- 删除用户:userdel