Leetcode_185_部门工资前三高的所有员工_SQL

with t as (
    select id, name as 'Employee', Salary, DepartmentId, dense_rank() over(partition by DepartmentId  order by salary desc) as 'rank'
    from employee
)

select d.name as 'Department',t.Employee, t.Salary
from t
left join Department as d on t.DepartmentId = d.id
where t.rank <= 3

partition by,按某字段切分,例如partition by 班级,就是每个班级独自排名
order by,与常规order by用法一致,也区分ASC(默认)和DESC,因为排名总得有个依据

如果会用函数的话,这题其实很简单,先算个rank,然后过滤一下rank<=3就行了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值