分析函数

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

分析函数和聚合函数的区别

普通的聚合函数用group by分组,每个分组返回一个统计值

分析函数采用partition by分组,并且每组每行都可以返回一个统计值

显而易见的区别是,从返回结果上看

聚合后的记录数可能会减少,因为它对数据源进行了group by操作,所以对结果是有影响的,即返回的结果里去掉聚合的列后,跟聚合前的结果不一样

而分析后的记录数是不变的,因为它的作用仅仅在于分析,所以不会对结果有影响,即返回的结果里去掉分析的列后,跟分析前的结果是一样的

分析函数的形式

分析函数要与开窗函数(over())一起使用,使用形式为:分析函数() over()

开窗函数(over())

开窗函数(over())包含三个分析子句:

分组子句(partition by)

排序子句(order by)

窗口子句(rows)

开窗函数(over())使用形式如下:

over(partition by xxx order by yyy rows between zzz)

开窗函数里的"窗",即"窗口",表示分析函数分析时要处理的数据范围

比如分析函数sum(),它所针对的数据范围为窗口中的记录,而不是整个表的记录

要获取某个范围的sum值,则需在窗口指定具体的数据范围

比如指定该窗口从该分组中的第一行到最后一行,那么该组中的每一个sum值都会一样,即整个组的总和

窗口子句除了rows方式的窗口,还包括range方式和滑动窗口

排序子句(order by)

开窗函数的order by和sql语句的order by的执行时机

分析及开窗函数(over())是在整个sql查询结束后再进行的, 即sql语句的order by也会影响分析函数的执行结果,有以下两种情况:

1) 两者一致,即sql语句中的order by语句与开窗函数的order by一致,则sql语句中的order by先执行,分析函数在分析时就不必再排序

2) 两者不一致,即sql语句中的order by语句与开窗函数的order by不一致,则分析及开窗函数先分析排序,sql语句中的order by再最后执行

窗口子句(rows)

如果没有窗口子句(rows),则默认当前组的第一行到当前行

无论是否省略分组子句,都有:

窗口子句(rows)不能单独存在,必须有order by子句时才能出现

相反,有order by子句,可以没有窗口子句(rows)

当省略窗口子句时

如果存在order by,则默认的窗口是unbounded preceding and current row,即当前组的第一行到当前行

如果不存在order by,则默认的窗口是unbounded preceding and unbounded following,即整个组

例如:lag(sal) over(order by sal)

over(order by salary)表示意义如下:

1) 由于省略分组子句,所以当前组的范围为整个表的数据行

2) 在当前组(此时为整个表的数据行)这个范围里执行排序,即order by salary

3) 分析函数lag(sal)在当前组(此时为整个表的数据行)这个范围里的窗口范围为当前组的第一行到当前行,即分析函数lag(sal)在这个窗口范围执行

窗口子句(rows)的相关关键字:

preceding:表示在...之前

1 preceding:表示当前记录的前1条记录

2 preceding:表示当前记录的前2条记录

n preceding:表示当前记录的前n条记录

unbounded preceding:不受控制的,无限的,

若无分组,则表示所有记录的第1条记录

若有分组,则表示分组后,组内的第1条记录

following:表示在...之后

1 following:表示当前记录的后一条记录

2 following:表示当前记录的后两条记录

n following:表示当前记录的后n条记录

unbounded following:不受控制的,无限的,

若无分组,则表示所有记录的最后一条记录

若有分组,则表示分组后,组内的最后一条记录

相关用例:

rows between unbounded preceding and unbounded following:针对所有记录

rows between unbounded preceding and current row:针对第一条记录到当前记录

rows between current row and unbounded following:针对当前记录到最后一条记录

rows between 1 preceding and current row:针对当前记录的上一行记录到当前行记录

rows between current row and 3 following:针对当前记录到当前行记录的后三条记录

rows between 1 preceding and 2 following:针对当前记录的上一条记录 ~~ 当前行记录的后两条记录

当开窗函数over()出现分组(partition by)子句时

unbounded preceding即表中一个分组里的第一行,unbounded following即表中一个分组里的最后一行

当开窗函数over()省略了分组(partition by)子句时

unbounded preceding即表中的第一行, unbounded following即表中的最后一行

使用示例:

selectt.id,

t.name,

t.city,

t.sales,--按城市分组,且组内销量升序排列,并获取当前记录针对上一条记录到下一条记录范围内的最小销量值

min(t.sales) over(partition by t.city order by t.sales rows between 1 preceding and 1 following) ascol1,--按城市分组,且组内销量升序排列,并获取当前记录针对第一条记录到当前记录范围内的最小销量值

min(t.sales) over(partition by t.city order by t.sales rows between unbounded preceding and current row) ascol2,--按城市分组,且组内销量升序排列,并获取当前记录针对上三条记录到当前记录范围内的最小销量值

min(t.sales) over(partition by t.city order by t.sales rows between 3 preceding and current row) ascol3from dataset t

原文:https://www.cnblogs.com/shiliye/p/12363300.html

oracle 开窗子句,分析函数和开窗函数相关推荐

  1. oracle stddev pop,Oracle的统计分析函数(STDDEV函数)

    STDDEV 功能描述:计算当前行关于组的标准偏离.( Standard Deviation )即标准差 1.标准差的定义及公式 标准差(Standard Deviation),在概率统计中最常使用作 ...

  2. 利用分析函数和开窗函数进行分组查询

    分析函数之分组排序 1.分析函数释义     row_number() OVER ( PARTITION BY COL1 ORDER BY COL2) 表示根据COL1分组,在分组内部根据 COL2排 ...

  3. 【学习笔记】分析函数(开窗函数)

    分析函数 这里的分析函数也就是我们常说的开窗函数,通常有两类: 一类是聚合开窗函数(SUM.AVG.MAX.MIN.COUNT等), 一类是排序开窗函数(ROW_NUMBER.DENSE_RANK.R ...

  4. oracle常用分析函数与聚合函数的用法

    今天是2019年第一天,在此祝大家新年快乐,梦想还在路上,让我们继续加油! 应之前的计划,今天完成这篇记录,也借此记录自己的成长. 一.几个排名函数的语法和用法: rank ( )  over ([p ...

  5. oracle上浮下浮分析函数_Oracle SQL高级编程——分析函数(窗口函数)全面讲解...

    Oracle SQL高级编程--分析函数(窗口函数)全面讲解 概述 分析函数是以一定的方法在一个与当前行相关的结果子集中进行计算,也称为窗口函数. 一般结构为 Function(arg1 , arg2 ...

  6. Oracle进阶(三)常用函数

    目录 1.聚合函数 2.转换函数 3.字符函数 4.数值函数 5.日期函数 6.判断函数 7.分析函数 附表 1.聚合函数 常用的SQL 聚合函数有5个:最大(MAX) 最小(MIN) 平均(AVG) ...

  7. Oracle窗口函数和分析函数

    一.前言描述: 分析函数带有一个开窗函数over(),包含三个分析子句:分组(partition by), 排序(order by),窗口(rows) ,他们的使用形式如下:分析函数名(参数) ove ...

  8. oracle 不等函数,SQL(Oracle)日常使用与不常使用函数的汇总

    --日常使用的sql语句和oracle语句,有些相对使用的频率比较高,收藏起来还是比较值得的 -- 绝对值 SQL:select abs(-1) value Oracle:select abs(-1) ...

  9. 利用Oracle内置分析函数进行高效统计汇总

    利用Oracle内置分析函数进行高效统计汇总 分析函数是Oracle从8.1.6开始引入的一个新的概念,为我们分析数据提供了一种简单高效的处理方式.在分析函数出现以前,我们必须使用自联查询,子查询或者 ...

最新文章

  1. Tomcat中的线程池(APR和ThreadPool)
  2. Session对象的集合
  3. [翻译]Feedback on the Go Challenge solutions
  4. Safari浏览器不支持……
  5. php event_base_new,php event拓展基本使用
  6. ARM 编译选项的默认关系 001
  7. matplotlib axis
  8. centos 7 vs centos6 的不同
  9. 这行简单的网址可令Chrome立马崩溃
  10. Recovery启动流程(1)--- 应用层到开机进入recovery详解
  11. 线粒体和叶绿体的基因组特点_线粒体和叶绿体基因组的组织及表达解析.ppt
  12. idea设置author注解
  13. I. 知识图谱 应用案例
  14. 无人驾驶汽车系统入门(十五)——ROS入门与实践(2)
  15. 华为荣耀路由器虚拟服务器,荣耀路由器怎么设置?
  16. 免费网盘如何选择@2020年
  17. 【操作系统】操作系统极速入门
  18. dsa数字签名c语言编程,DSA 数字签名算法
  19. 一窥深度学习黑箱,拼接深层神经网络架构
  20. android内存问题详解--重要

热门文章

  1. 使用 coding.net 发布你的个人博客
  2. R语言绘制环形树状图
  3. MPB:农科院牧医所赵圣国组-微生物超高分子量DNA提取方法
  4. 专属含PCR抑制剂的环境样本微生物拷贝数定量的最佳解决方案!
  5. mysql内存爆_线上MySQL机器内存爆掉原因分析与解决
  6. R语言可视化分面图、多变量分组多水平t检验、可视化多变量分组多水平分面条形图(faceting bar plot)并添加显著性水平、在标签和绘图上边框之间添加15%的空格、添加抖动数据点
  7. R语言螺旋线型线性不可分数据xgboost分类:使用xgboost模型来解决螺旋数据的分类问题、可视化模型预测的结果、添加超平面区域渲染并与原始数据标签进行对比分析
  8. R语言使用apriori算法进行关联规则挖掘实战:关联规则概念、频繁项集、支持度(support)、置信度(confidence)、提升度(lift)、apriori算法
  9. 关系型数据库和非关系型数据库的优劣对比?
  10. python使用base64编码解码数据