oracle排列rank函数

上传人:xiao****1972 文档编号:84085156 上传时间:2019-03-02 格式:DOC 页数:11 大小:39.50KB
返回 下载 相关 举报
oracle排列rank函数_第1页
第1页 / 共11页
oracle排列rank函数_第2页
第2页 / 共11页
oracle排列rank函数_第3页
第3页 / 共11页
oracle排列rank函数_第4页
第4页 / 共11页
oracle排列rank函数_第5页
第5页 / 共11页
点击查看更多>>
资源描述

《oracle排列rank函数》由会员分享,可在线阅读,更多相关《oracle排列rank函数(11页珍藏版)》请在金锄头文库上搜索。

1、排列(rank())函数。这些排列函数提供了定义一个集合(使用 PARTITION 子句),然后根据某种排序方式对这个集合内的元素进行排列的能力,下面以scott用户的emp表为例来说明rank over partition如何使用1)查询员工薪水并连续求和select deptno,ename,sal,sum(sal)over(order by ename) sum1, /*表示连续求和*/sum(sal)over() sum2, /*相当于求和sum(sal)*/100* round(sal/sum(sal)over(),4) bal%from emp结果如下: DEPTNO ENAME

2、SAL SUM1 SUM2 bal%- - - - - - 20 ADAMS 1100 1100 29025 3.79 30 ALLEN 1600 2700 29025 5.51 30 BLAKE 2850 5550 29025 9.82 10 CLARK 2450 8000 29025 8.44 20 FORD 3000 11000 29025 10.34 30 JAMES 950 11950 29025 3.27 20 JONES 2975 14925 29025 10.25 10 KING 5000 19925 29025 17.23 30 MARTIN 1250 21175 29025

3、 4.31 10 MILLER 1300 22475 29025 4.48 20 SCOTT 3000 25475 29025 10.34 DEPTNO ENAME SAL SUM1 SUM2 bal%- - - - - - 20 SMITH 800 26275 29025 2.76 30 TURNER 1500 27775 29025 5.17 30 WARD 1250 29025 29025 4.312)如下:select deptno,ename,sal,sum(sal)over(partition by deptno order by ename) sum1,/*表示按部门号分氏,按姓

4、名排序并连续求和*/sum(sal)over(partition by deptno) sum2,/*表示部门分区,求和*/sum(sal)over(partition by deptno order by sal) sum3,/*按部门分区,按薪水排序并连续求和*/100* round(sal/sum(sal)over(),4) bal%from emp结果如下: DEPTNO ENAME SAL SUM1 SUM2 SUM3 bal%- - - - - - - 10 CLARK 2450 2450 8750 3750 8.44 10 KING 5000 7450 8750 8750 17.

5、23 10 MILLER 1300 8750 8750 1300 4.48 20 ADAMS 1100 1100 10875 1900 3.79 20 FORD 3000 4100 10875 10875 10.34 20 JONES 2975 7075 10875 4875 10.25 20 SCOTT 3000 10075 10875 10875 10.34 20 SMITH 800 10875 10875 800 2.76 30 ALLEN 1600 1600 9400 6550 5.51 30 BLAKE 2850 4450 9400 9400 9.82 30 JAMES 950 54

6、00 9400 950 3.27 DEPTNO ENAME SAL SUM1 SUM2 SUM3 bal%- - - - - - - 30 MARTIN 1250 6650 9400 3450 4.31 30 TURNER 1500 8150 9400 4950 5.17 30 WARD 1250 9400 9400 3450 4.313)如下:select empno,deptno,sal,sum(sal)over(partition by deptno) deptSum,/*按部门分区,并求和*/rank()over(partition by deptno order by sal des

7、c nulls last) rank, /*按部门分区,按薪水排序并计算序号*/dense_rank()over(partition by deptno order by sal desc nulls last) d_rank,row_number()over(partition by deptno order by sal desc nulls last) row_rankfrom emp注:rang()涵数主要用于排序,并给出序号dense_rank():功能同rank()一样,区别在于,rank()对于排序并的数据给予相同序号,接下来的数据序号直接跳中跃,dense_rank()则不是,

8、比如数据:1,2,2,4,5,6.。这是rank()的形式 1,2,2,3,4,5,。这是dense_rank()的形式 1,2,3,4,5,6.。这是row_number()涵数形式row_number()涵数则是按照顺序依次使用,相当于我们普通查询里的rownum值其实从上面三个例子当中,不难看出over(partition by . order by .)的整体概念,我理解是partition by :按照指字的字段分区,如果没有则针对全体数据order by :按照指定字段进行连续操作(如求和(sum),排序(rank()等),如果没有指定,就相当于对指定分区集合内的数据进行整体sum

9、操作oracle聚合函数rank()的用法SQL select * from test_a;ID PLAYNAME SCORE- - -01 aa 10002 aa 10102 bb 9903 bb 9804 aa 10102 aa 101需求是,将score降序排序,打印所有字段,并且如果是同一个playname的score只取出最高分,如果这个playname获得过多个相同的最高分,则只取出其中一个(比如:aa获得过3次101,则只取其中一个),最终要的结果就是: RK ID PALYNAME SCORE- - - - 1 02 aa 101 1 02 bb 99本来我想用max函数,结果直接就出来了:SQL select ma

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号