力扣SQL题(中等)请教语句错误原因

Employee 表包含所有员工信息,每个员工有其对应的 Id, salary 和 department Id。

+----+-------+--------+--------------+
| 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    |
+----+----------+
编写一个 SQL 查询,找出每个部门工资最高的员工。对于上述表,您的 SQL 查询应返回以下行(行的顺序无关紧要)。

+------------+----------+--------+
| Department | Employee | Salary |
+------------+----------+--------+
| IT         | Max      | 90000  |
| IT         | Jim      | 90000  |
| Sales      | Henry    | 80000  |
+------------+----------+--------+
解释:

Max 和 Jim 在 IT 部门的工资都是最高的,Henry 在销售部的工资最高。

答题:

SELECT

    Department.name AS 'Department',

    Employee.name AS 'Employee',

    salary

FROM

    Employee

        JOIN

    Department ON Employee.DepartmentId = Department.Id

where Salary in

 (select 

 first_alue(Salary) over(partition by DepartmentId order by Salary desc) as max_Salary

 from Employee)

IT 部门有 9000 的,但你的 where 条件如果其他部门有 9000 的也会筛选出来。单看 where,查询出每个部门的最高工资,但这个要和部门匹配的。可以试试标量子查询来限定工资。