Sql力扣算法:185. 部门工资前三高的所有员工

力扣链接:
https://leetcode.cn/problems/department-top-three-salaries/submissions/

题目描述:

SQL架构
表: Employee
在这里插入图片描述
Id是该表的主键列。
departmentId是Department表中ID的外键。
该表的每一行都表示员工的ID、姓名和工资。它还包含了他们部门的ID。

表: Department
在这里插入图片描述
Id是该表的主键列。
该表的每一行表示部门ID和部门名。

公司的主管们感兴趣的是公司每个部门中谁赚的钱最多。一个部门的 高收入者 是指一个员工的工资在该部门的 不同 工资中 排名前三

编写一个SQL查询,找出每个部门中 收入高的员工 。

以 任意顺序 返回结果表。

查询结果格式如下所示。

案例:

在这里插入图片描述

解决方案:

代码:

/* Write your T-SQL query statement below */

select c.name Department,a.name Employee,a.salary Salary from Employee a    --各个部门的前三高工资
left join  (
    select a.departmentId,max(a.salary) MaxSalary from Employee a  --各个部门的第三高工资
        left join (
            select a.departmentId,max(a.salary) MaxSalary from Employee a left join --各个部门的第二高工资
            (select max(a.salary) MaxSalary,a.departmentId from Employee a group by departmentId) b --各个部门的最高工资
            on a.departmentId = b.departmentId
            where a.salary < b.MaxSalary
            group by a.departmentId
        ) b on a.departmentId = b.departmentId
    where a.salary < b.MaxSalary
    group by a.departmentId
) b on a.departmentId = b.departmentId
left join Department c on a.departmentId = c.id
where a.salary >= isnull(b.MaxSalary,0)

提交结果:

在这里插入图片描述

解题思路:

1.根据部门group by获得各个部门的最高工资,将其封装成子查询表T1。

2.用一个Employee 根据部门关联子查询表T1,where 工资小于子查询表的最高工资,再根据部门group by获取各个部门的第二高工资,将其封装成子查询表T2。

3.用一个Employee 根据部门关联子查询表T2,where 工资小于子查询表的第二高工资,再根据部门group by获取各个部门的第三高工资,将其封装成子查询表T3。

4.用Employee 根据部门关联子查询表T3,关联Department 表,获取所有数据,Where工资大于等于T3的isnull(第三高工资,0),填写需要取出字段。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值