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
然后分析题意提取条件
- 因为是求取每个部门的最高薪资员工,而员工表employee还有外键约束,输出内容需要部门信息。所以,Department也被需要。需要一个join
employee e inner join department d on e.departmentId=d.id - 因为是求取每个部门的最高薪资,所以需要先将每个部门的最高薪资求取出来。然后去里面找内容比较就行了 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;