首页 > 代码库 > 给群里的哥们写的sql(row_number、rank、dense_rank)
给群里的哥们写的sql(row_number、rank、dense_rank)
<span style="font-size:18px;">最近精力比较有限,有些常用的东西就先记录下来。方便以后自己查阅和总结。</span>
一个哥们想要实现如下效果:
DEPTNO ENAME SAL TOP3 部门工资 排序 ---------- ---------- ---------- ---------- 20 KING 5000 1 8750 2 20 CLARK 2450 2 8750 2 20 MILLER 1300 3 8750 2 10 SCOTT 3000 1 8975 1 10 FORD 3000 2 8975 1 10 JONES 2975 3 8975 1 30 BLAKE 2850 1 5950 3 30 ALLEN 1600 2 5950 3 30 TURNER 1500 3 5950 3
从上图可以看出,他想要实现部门的总工资排名。这个就要用到我们常说的分析函数了。分析函数是什么,这里就不多说了。有兴趣的朋友,请自己查阅官方文档。
下面我们来实现上图的功能:
首先,第一步我们需要先求出每个部门的总工资,SQL如下:
select deptno, ename, sal, sum(sal) over(partition by deptno order by deptno) as sumsal from emp查询的结果集:
第二步,我们就要实现最终的功能,附上SQL:
select deptno, ename, sal, sumsal, row_number() over(partition by deptno order by sal) as "部门内排名", dense_rank() over(order by sumsal) as "部门排名" from (select deptno, ename, sal, sum(sal) over(partition by deptno order by deptno) as sumsal from emp)
结果集如下:
图片显示的效果,就是我们想要的最终结果。以后在附上相关分析函数的使用效果。今天就到这,上班了。。。。
给群里的哥们写的sql(row_number、rank、dense_rank)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。