【SQL】部门工资最高的员工

一、题目描述

表: Employee

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

输入:
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 在销售部的工资最高。

二、代码题解
# Write your MySQL query statement below
select
    Department.name as 'Department',
    Employee.name as 'Employee',
    Employee.salary as Salary
from
    Employee 
        join 
    Department on Employee.departmentId = Department.id
where 
    (Employee.departmentId , Employee.salary) in
    (   select 
            departmentId,max(salary)
        from 
            Employee
        group by departmentId   
    );

这样的代码也可以,但是针对薪资同样高的人,名字会不同,但是group by会自动帮我们去重一个,而且这样做也会有问题,因为对departmentId 分的组,但是我们字段却有name,这个name的数量和分组的数量可不一定相同,所以会出bug。

		select 
            departmentId,name,max(salary)
        from 
            Employee
        group by departmentId 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值