forked from shuboc/LeetCode-2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
department-top-three-salaries.sql
48 lines (47 loc) · 1.86 KB
/
department-top-three-salaries.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# Time: O(n^2)
# Space: O(n)
#
# The Employee table holds all employees. Every employee has an Id, 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 |
# | 5 | Janet | 69000 | 1 |
# | 6 | Randy | 85000 | 1 |
# +----+-------+--------+--------------+
# The Department table holds all departments of the company.
#
# +----+----------+
# | Id | Name |
# +----+----------+
# | 1 | IT |
# | 2 | Sales |
# +----+----------+
# Write a SQL query to find employees who earn the top three salaries in each of the department. For the above tables, your SQL query should return the following rows.
#
# +------------+----------+--------+
# | Department | Employee | Salary |
# +------------+----------+--------+
# | IT | Max | 90000 |
# | IT | Randy | 85000 |
# | IT | Joe | 70000 |
# | Sales | Henry | 80000 |
# | Sales | Sam | 60000 |
# +------------+----------+--------+
# Write your MySQL query statement below
SELECT D.Name AS Department, E.Name AS Employee, E.Salary AS Salary
FROM Employee E INNER JOIN Department D ON E.DepartmentId = D.Id
WHERE (SELECT COUNT(DISTINCT(Salary)) FROM Employee
WHERE DepartmentId = E.DepartmentId AND Salary > E.Salary) < 3
ORDER by E.DepartmentId, E.Salary DESC;
#or without subquery
SELECT D.Name as Department, E.Name as Employee, E.Salary
FROM Department D, Employee E, Employee E2
WHERE D.ID = E.DepartmentId and E.DepartmentId = E2.DepartmentId and
E.Salary <= E2.Salary
group by D.ID,E.Name having count(distinct E2.Salary) <= 3
order by D.Name, E.Salary desc