Employee 表包含所有员工信息,每个员工有其对应的 Id, salary 和 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
---- ------- -------- --------------

Department 表包含公司所有部门的信息。

|----|----------|

Id Name
1 IT
2 Sales
---- ----------

编写一个 SQL 查询,找出每个部门工资前三高的员工。例如,根据上述给定的表格,查询结果应返回:

|------------|----------|--------|

Department Employee Salary
IT Max 90000
IT Randy 85000
IT Joe 70000
Sales Henry 80000
Sales Sam 60000
------------ ---------- --------
1
2
3
4
5
--此处若有两个相同的薪水  只占一个前三的名额  需要使用dense_rank()over()函数
select B.name Department ,A.name Employee ,A.Salary from
(select Salary,Name,DepartmentId ,dense_rank()OVER(PARTITION BY DepartmentId ORDER BY Salary desc) num from Employee ) A
join Department B on A.DepartmentId=B.ID
where A.num<=3