Oralce开窗函数OVER()的一些应用
好久没用oracle了,发现很多东西已经忘记.正好今天改写个语句,顺便回忆了一下,乘热整理以备遗忘.
over(order by salary) 按照salary排序进行累计,order by是个默认的开窗函数
over(partition by deptno)按照部门分区
over(order by salary range between 50 preceding and 150 following) 每行对应的数据窗口是之前行幅度值不超过50,之后行幅度值不超过150
over(order by salary rows between 50 preceding and 150 following) 每行对应的数据窗口是之前50行,之后150行
over(order by salary rows between unbounded preceding and unbounded following) 每行对应的数据窗口是从第一行到最后一行,等效:
over(order by salary range between unbounded preceding and unbounded following)
主要参考资料:《expert one-on-one》 Tom Kyte 《Oracle9i SQL Reference》第6章
首先我们用语句构建一个临时表,用于下面的演示:
with test as
(
select rownum as n,mod(rownum,2) as grp from dual
connect by rownum<=10
)
select * from test 结果如下:
N GRP
1 1
2 0
3 1
4 0
5 1
6 0
7 1
8 0
9 1
10 0
使用聚合函数
1.AVG
功能描述:用于计算一个组和数据窗口内表达式的平均值。
SAMPLE:下面的例子中计算奇数和偶数列的平均值
with test as
(
select rownum as n,mod(rownum,2) as grp from dual
connect by rownum<=10
)
--后面的例子中将省略去上面部分
select avg(n) over(partition by grp) as avg_n,n
from test
结果:

--加入order by 后的效果,自己观察
select avg(n) over (partition by grp order by n) as avg_n,n
from test

2.CORR
功能描述:返回一对表达式的相关系数
3.COVAR_SAMP
功能描述:返回一对表达式的样本协方差
4.COUNT
功能描述:对一组内发生的事情进行累积计数
5.CUME_DIST
功能描述:计算一行在组中的相对位置
以上都是常见的聚合函数,当然还包括: max,min等等.
区别就是只使用聚合函数将仅显示各个分组的统计结果,和over()联合使用后会同时显示各个样本数据和统计结果.
所以不在一一进行测试,几乎所有的聚合函数都可以这样使用.
排行函数
1.row_number,rank,DENSE_RANK
功能描述:对一组数据按某些属性进行排序,它们之前的区别举例如下:
3个人考试:A 100分 B 100分 C90分
对于row_number来说不允许排名相同结果如下:
A 第1名 B 第2名 C 第3名
rank则允许名次相同:
A 第1名 B 第1名 C 第3名
DENSE_RANK允许名称相同的情况,同时要求排名必须连续:
A 第1名 B 第1名 C 第2名
SAMPLE:
按奇偶数进行分组并进行排序
select row_number() over (partition by grp order by n ) as rn,n
from test
结果:

三者的区别演示:
select rank() over (order by grp) as rk
,DENSE_RANK() over (order by grp) as drk
,row_number() over (order by grp) as rn
,n
from test
结果:

2.Lead,Lag
功能描述:对一组记录排序后,取当前行之后或之前的某一条的值
SAMPLE:按奇偶分组,排序后取后面第2条和前面第2条记录值
select lag(n,2) over(partition by grp order by n) as next_n
,lead(n,2) over (partition by grp order by n) as prev_n
,n,grp
from test
结果如下:

3.Last_value,First_value
功能描述:对一组记录排序后,取所在分组的第一条或最后一条记录
SAMPLE:按奇偶分组,排序后取最后一条和第一条的值
select last_value(n) over(partition by grp order by n) as last_N
,first_value(n) over (partition by grp order by n) as first_n
,n,grp
from test

注意:last 实际是截止到当前行的最后一条记录,这样如果想取最后一条怎么办?当然是用first_value(n) over (partition by grp order by n desc)
正数最后一名就是倒数第一名.
Oralce开窗函数OVER()的一些应用的更多相关文章
- 开窗函数 First_Value 和 Last_Value
在Sql server 2012里面,开窗函数丰富了许多,其中带出了2个新的函数 First_Value 和 Last Value .现在来介绍一下这2个函数的应用场景. 首先分析一下First_Va ...
- Oracle开窗函数 over()(转)
copy文链接:http://blog.csdn.net/yjjm1990/article/details/7524167#,http://www.2cto.com/database/201402/2 ...
- oracle的分析函数over 及开窗函数
转:http://www.2cto.com/database/201310/249722.html oracle的分析函数over 及开窗函数 一:分析函数over Oracle从8.1.6开 ...
- 开窗函数 --over()
一个学习性任务:每个人有不同次数的成绩,统计出每个人的最高成绩. 这个问题应该还是相对简单,其实就用聚合函数就好了. select id,name,max(score) from Student gr ...
- SQL使用开窗函数与CTE查询每月销售额的前几名
WITH tagTab AS( SELECT YearMonth, pm=RANK() OVER(PARTITION BY YearMonth ORDER BY amount DESC) FROM S ...
- 利用OVER开窗函数分页
在SQL Server中,利用SQL进行分页的方法也有很多,今天要总结的是SQL Server 2005中引入的OVER开窗口函数,然后利用开窗函数进行分页. 示例代码如下: -- 设置数据库上下文 ...
- sqlserver开窗函数
从 http://jimshu.blog.51cto.com/3171847/1376637/ 转 开窗函数是在 ISO 标准中定义的.SQL Server 提供排名开窗函数和聚合开窗函数. 在开窗函 ...
- SQL ServerOVER 子句,over开窗函数,SQL SERVER 开窗函数
https://technet.microsoft.com/zh-cn/library/ms189461(v=sql.105).aspx http://www.cnblogs.com/85538649 ...
- sql over开窗函数,
sql over开窗函数, 1.使用over子句与rows_number()以及聚合函数进行使用,可以进行编号以及各种操作.而且利用over子句的分组效率比group by子句的效率更高. 2.在订单 ...
随机推荐
- HDU 5862(离散化+树状数组)
Problem Counting Intersections 题目大意 给定n条水平或竖直的线段,统计所有线段的交点个数. (n<=100000) 解题分析 首先将线段离散化. 然后将所有线段按 ...
- C,C++宏中#与##的讲解[转]
MoreWindows 专注于Windows编程 C,C++宏中#与##的讲解 文中__FILE__与示例1可以参见<使用ANSI C and Microsoft C++中常用的预定义宏> ...
- 重装系统后删除Cygwin文件夹
1.右键点要删除Cygwin 文件夹,依次选属性-安全-高级-所有者-编辑,将所有者改为你的登录帐户,勾选下方“替换子容器和对象的所有者”. 2.在 属性-安全-高级对话框中选 权限选项卡,点更改权限 ...
- HTTP一次请求的过程
一次完整的HTTP请求所经历的7个步骤 HTTP通信机制是在一次完整的HTTP通信过程中,Web浏览器与Web服务器之间将完成下列7个步骤: 1. 建立TCP连接在HTTP工作开始之前,Web浏览器首 ...
- java类型转化之Hbase ImmutableBytesWritable类型转String
Hbase 的ImmutableBytesWritable类型一般作为RowKey的类型;但也有时候会把值读出来;故有了转化为string一说. ImmutableBytesWritable RowK ...
- 神逸之作:国产快速启动软件神品ALTRun
http://xbeta.info/altrun.htm 作者: ET民工和塞壬 日期: 2010-09-15 分类: windows 标签: quick-launch <神逸之作:国产快速启动 ...
- hdu 5206 Four Inages Strategy
题目大意: 判断空间上4个点是否形成一个正方形 分析: 标称思想 : 在p2,p3,p4中枚举两个点作为p1的邻点,不妨设为pi,pj,然后判断p1pi与p1pj是否相等.互相垂直,然后由向量法,最后 ...
- 隐马尔科夫模型(HMM)的概念
定义隐马尔科夫模型可以用一个三元组(π,A,B)来定义:π 表示初始状态概率的向量A =(aij)(隐藏状态的)转移矩阵 P(Xit|Xj(t-1)) t-1时刻是j而t时刻是i的概率B =(bij) ...
- 瓜娃《guava》api快速入门
1,大纲 让我们来熟悉瓜娃,并体验下它的一些API,分成如下几个部分: Introduction Guava Collection API Guava Basic Utilities IO API C ...
- 1-4-1 Windows应用程序组成及编程步骤
主要内容:介绍Windows应用程序的组成以及编程步骤 1.应用程序的组成 <1>一个完整的应用程序通常由五种类型的文件组成 1.源程序文件 2.头文件 3.模块定义文件 4.资源描述文件 ...