题目
有两张表Employee和Department,要求如题
- 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 |
±—±---------+
- ⚠️多个员工薪水都是最高,都需要输出
使用JOIN和IN从句
- 分组自然想到GROUP BY
SELECT
DepartmentId, MAX(Salary)

该博客探讨了如何在MySQL中解决一个问题,即如何找出每个部门薪水最高的员工,即使可能存在多个员工薪水相同且最高。通过使用JOIN和IN从句,结合GROUP BY语句,可以获取每个部门的最高薪水,但原始方法只返回一个员工。博主提供了利用临时表来解决这个问题的方法,确保所有最高薪水的员工都能被正确输出。
最低0.47元/天 解锁文章
2182

被折叠的 条评论
为什么被折叠?



