美文网首页
184. Department Highest Salary

184. Department Highest Salary

作者: 无敌的肉包 | 来源:发表于2018-06-07 15:54 被阅读0次

    The Employeetable holds all employees. Every employee has an Id, a salary, and there is also a column for the department Id.

    +----+-------+--------+--------------+
    | Id | Name  | Salary | DepartmentId |
    +----+-------+--------+--------------+
    | 1  | Joe   | 70000  | 1            |
    | 2  | Henry | 80000  | 2            |
    | 3  | Sam   | 60000  | 2            |
    | 4  | Max   | 90000  | 1            |
    +----+-------+--------+--------------+
    

    The Department table holds all departments of the company.

    +----+----------+
    | Id | Name     |
    +----+----------+
    | 1  | IT       |
    | 2  | Sales    |
    +----+----------+
    

    Write a SQL query to find employees who have the highest salary in each of the departments. For the above tables, Max has the highest salary in the IT department and Henry has the highest salary in the Sales department.

    +------------+----------+--------+
    | Department | Employee | Salary |
    +------------+----------+--------+
    | IT         | Max      | 90000  |
    | Sales      | Henry    | 80000  |
    +------------+----------+--------+
    

    SELECT b.Name AS 'Department', a.Name AS 'Employee', Salary
    FROM Employee AS a INNER JOIN Department AS b
    ON a.DepartmentId = b.Id 
    WHERE (a.DepartmentId, Salary) IN(
        SELECT DepartmentId, MAX(Salary)
        FROM Employee
        GROUP BY DepartmentId
        )
        
    

    相关文章

      网友评论

          本文标题:184. Department Highest Salary

          本文链接:https://www.haomeiwen.com/subject/lypgsftx.html