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函数总结相关推荐

  1. Oracle分析函数一——函数列表

    Oracle 分析函数 Oracle 分析函数--函数列表 SUM         : 该函数计算组中表达式的累积和 MIN         : 在一个组中的数据窗口中查找表达式的最小值 MAX    ...

  2. oracle 四分位函数,Oracle分析函数四——函数RANK,DENSE_RANK,FIRST,LAST…

    Oracle 分析函数--函数RANK,DENSE_RANK,FIRST,LAST- RANK 功能描述:根据 ORDER BY 子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置.组内 ...

  3. Oracle分析函数四——函数RANK,DENSE_RANK,FIRST,LAST…

    Oracle分析函数--函数RANK,DENSE_RANK,FIRST,LAST- RANK 功能描述:根据ORDER BY子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置.组内的数据 ...

  4. oracle分析函数-开窗函数

    oracle分析函数 分析函数是什么? 分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计值. ...

  5. Oracle分析函数七——函数案例

    环比 环比就是现在的统计周期和上一个统计周期比较.例如2008年7月份与2008年6月份相比较称其为环比. 环比发展速度是报告期水平与前一时期水平之比,表明现象逐期的发展速度.如计算一年内各月与前一个 ...

  6. DEV03-GBase 8a MPP Cluster OLAP 函数

    GBase 8a MPP Cluster OLAP 函数 一.OLAP函数的基本概念 二.OLAP 函数分类: 三.窗口类 OLAP 函数 (一)概念: (二)语法: (三) 主函数 四.GROUP ...

  7. Oracle分析函数——函数列表

    --------------聚合函数 SUM :该函数计算组中表达式的累积和 MIN :在一个组中的数据窗口中查找表达式的最小值 MAX :在一个组中的数据窗口中查找表达式的最大值 AVG :用于计算 ...

  8. Oracle分析函数、多维函数和Model函数简要说明,主要针对BI报表统计

    以下代码均经过测试,可直接运行 Oracle分析函数.多维函数和Model函数简要说明,主要针对BI报表统计,不一定很全面,但对BI应用场景做了少许说明 --创建一张销售数量表,数据趋势是递增的 CR ...

  9. oracle 分析函数、GROUPING函数

    分析函数 over(Partition by...) 一个超级牛皮的ORACLE特有函数.天天都用ORACLE,用了快2年了.最近才接触到这个功能强大而灵活的函数.真实惭愧啊!oracle的分析函数o ...

最新文章

  1. 进度条三方库tdqm trange用法
  2. php向数据库添加数据失败,无法从PHP中的表单向数据库添加数据
  3. 能玩java游戏oppo按键手机_游戏手机排行榜|OPPO Reno果然不负期待
  4. prima evb_用Priam设置Cassandra
  5. LeetCode 992. K 个不同整数的子数组(双指针)
  6. linux下网络编程设置非阻塞,UNIX网络编程 非阻塞connect的实现
  7. 如何计算MySQL数据库占用内存
  8. 11.Linux 高性能服务器编程 --- 定时器
  9. 判断变量是空_python基础(二):变量的数据类型、常量、操作符、分支、循环、条件判断...
  10. html5 拖放游戏,HTML5拖放API实现拖放排序的实例代码
  11. 从零开始设计一个右键菜单组件
  12. 卷积操作中的group
  13. 场景文字识别论文阅读
  14. 命令点亮硬盘灯_【硬盘无法识别怎么办?】
  15. 数学速算法_小数减法如何学?3种心算速算法,快捷有效,让孩子爱上数学
  16. 什么是熔断、降级、限流
  17. 毕业设计-基于深度学习的图像隐写分析
  18. Linux驱动学习笔记之触摸屏驱动
  19. html页面执行sql语句,关于在页面上执行sql语句
  20. 删除用户:userdel

热门文章

  1. 1042 字符统计 (20 分)(c语言)
  2. golang中如何抓取panic让程序正常退出
  3. 从字节码角度解释i++和++i
  4. Shell(11)——awk(1)
  5. PX4飞控之导航及任务架构
  6. 修复kali grub引导
  7. linux多线程信号总结
  8. Linux多线程之线程同步(条件变量)
  9. android 流量统计不准确_汽车里程表上显示的百公里油耗准确吗?是不是真的是欢乐表...
  10. assembly plugin实现自定义打包