MYSQL刷题题解_力扣_查找每个部门中薪资最高的员工。

1、题目描述

表: Employee

+--------------+---------+
| 列名          | 类型    |
+--------------+---------+
| id           | int     |
| name         | varchar |
| salary       | int     |
| departmentId | int     |
+--------------+---------+
id是此表的主键列。
departmentId是Department表中ID的外键。
此表的每一行都表示员工的ID、姓名和工资。它还包含他们所在部门的ID。
表: Department

+-------------+---------+
| 列名         | 类型    |
+-------------+---------+
| id          | int     |
| name        | varchar |
+-------------+---------+
id是此表的主键列。
此表的每一行都表示一个部门的ID及其名称。

编写SQL查询以查找每个部门中薪资最高的员工。
按 任意顺序 返回结果表。
查询结果格式如下例所示。

示例 1:

输入:
Employee 表:
+----+-------+--------+--------------+
| id | name  | salary | departmentId |
+----+-------+--------+--------------+
| 1  | Joe   | 70000  | 1            |
| 2  | Jim   | 90000  | 1            |
| 3  | Henry | 80000  | 2            |
| 4  | Sam   | 60000  | 2            |
| 5  | Max   | 90000  | 1            |
+----+-------+--------+--------------+
Department 表:
+----+-------+
| id | name  |
+----+-------+
| 1  | IT    |
| 2  | Sales |
+----+-------+
输出:
+------------+----------+--------+
| Department | Employee | Salary |
+------------+----------+--------+
| IT         | Jim      | 90000  |
| Sales      | Henry    | 80000  |
| IT         | Max      | 90000  |
+------------+----------+--------+
解释:Max 和 Jim 在 IT 部门的工资都是最高的,Henry 在销售部的工资最高。

2、题目思路

老方法,假设一张表提取所有信息

select * from tablename

然后分析题意提取条件

  1. 因为是求取每个部门的最高薪资员工,而员工表employee还有外键约束,输出内容需要部门信息。所以,Department也被需要。需要一个join
    employee e inner join department d on e.departmentId=d.id
  2. 因为是求取每个部门的最高薪资,所以需要先将每个部门的最高薪资求取出来。然后去里面找内容比较就行了 salary in tablename
select departmentId  ,max(salary)
from employee 
group by departmentId ;

此时组合条件完成解题

select  d.name Department,e.name name,e.Salary 
       from Employee  as e inner join Department d
            on e.departmentId =d.id  
       where (e.departmentId,e.Salary )in
       #我这里没有去重,因为最高薪资的员工可以有多个。
       #不用考虑最后通过这个查出的员工信息是否有重复,这里只是筛选条件,是纯粹想多了,仔细思考以下就知道没必要
            (select departmentId ,max(salary) Salary
             from employee 
             group by departmentId ) ;
#因为是求最高薪资,所以可以使用排名窗口函数,拿取所有排名第一的员工信息即可
#注意下面e.*是不行的,我这里是图省事了,实际语法只能一个一个敲出来
with t as (
select  e.*,d.name Department ,dense_rank() over(
                    partation by e.departmentid
                    order by salary desc)  departRankSalary
     from Employee  as e 
     inner join 
     Department d 
     on e.departmentId =d.id  )
select t.Department,t.Employee ,t.Salary  from  where t.departRankSalary=1;
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值