测试使用的数据为scott/tiger模式下的emp表:函数
咱们使用JOB和SAL这两个列测试:测试
上面语句指按照职业JOB分组(partition by job)而后在每一个分组内,按照薪水(sal)进行排名。注意到并列名次,例如SLAESMAN这个职业的,有两个1250并列第一,1500就是第3名了。spa
将RANK()换成DENSE_RAND看看区别:3d
能够看到,在处理并列问题上,并列的名次不占用名次编号。blog
另外还有一个经常使用的分析函数是SUM() OVER:排序
SUM() OVER计算累计求和,从第一行开始,累计SAL列的值,注意到order by sal,若是不按照sal排序,结果会是这样:it
若是要针对每一个分组进行分别累计求和,则只需加上分区PARTITION BY:io