SQL_217

对所有员工的薪水按照salary降序进行1-N的排名

https://www.nowcoder.com/practice/b9068bfe5df74276bd015b9729eec4bf

方法一:

思路:

使用窗口函数 DENSE_RANK () OVER () 函数即可将实现薪水按照 salary 进行按照 1-N 的排名,相同 salary 并列。

补充:

RANK () OVER (ORDR BY < 列名>): 计算排名,如果存在相同位次的记录,则会跳过之后的位次。如,1,1,1,4

DENSE_RANK () OVER (ORDER BY < 列名>): 计算排序,即使存在相同为此的记录,也不会跳过之后的位次。如 1,1,1,2

ROW_NUMBER () OVER (ORDER BY < 列名>): 计算排序,赋予唯一的连续位次。如 1,2,3,4

代码:

select
    emp_no,
    salary,
    dense_rank() over (
        order by
            salary desc
    ) t_rank
from
    salaries
order by
    salary desc,
    emp_no asc

全部评论

相关推荐

02-21 23:34
已编辑
厦门大学 Java
神哥不得了:神哥来啦~首先你的bg的话应该算是很好的了,可以把其他删掉,不需要手搓项目呀,直接找网上的项目看懂就行,第一个项目的话虽然和JAVA没有关系,但是他的星数很多,说明你的编程能力还是很强的,我觉得第一个项目是可以放上去的,但是第二个项目的话建议还是再换一个高质量的项目,感觉如果你再把高频top 50的八股再巩固几遍,完全有机会在没有实习的情况下,从暑期实习的大厂,机会还是很大的,注意别看一些假高频八股就行
点赞 评论 收藏
分享
评论
2
2
分享

创作者周榜

更多
牛客网
牛客企业服务