LeetCode:Database 13.员工薪水中位数

Posted Xiao Miao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode:Database 13.员工薪水中位数相关的知识,希望对你有一定的参考价值。

要求:请编写SQL查询来查找每个公司的薪水中位数。挑战点:你是否可以在不使用任何内置的SQL函数的情况下解决此问题?

Employee 表:

+-----+------------+--------+
|Id   | Company    | Salary |
+-----+------------+--------+
|1    | A          | 2341   |
|2    | A          | 341    |
|3    | A          | 15     |
|4    | A          | 15314  |
|5    | A          | 451    |
|6    | A          | 513    |
|7    | B          | 15     |
|8    | B          | 13     |
|9    | B          | 1154   |
|10   | B          | 1345   |
|11   | B          | 1221   |
|12   | B          | 234    |
|13   | C          | 2345   |
|14   | C          | 2645   |
|15   | C          | 2645   |
|16   | C          | 2652   |
|17   | C          | 65     |
+-----+------------+--------+
表有三列:员工Id,公司名和薪水。

Result Table:

+-----+------------+--------+
|Id   | Company    | Salary |
+-----+------------+--------+
|5    | A          | 451    |
|6    | A          | 513    |
|12   | B          | 234    |
|9    | B          | 1154   |
|14   | C          | 2645   |
+-----+------------+--------+

分析:
1.需要求出每个公司的工资中位数,首先使用开窗函数row_number()进行分组和排序
2.使用窗口聚合函数count()求出每个分组的总员工数
3.最后筛选条件为中位数工资的序号等于总员工数/2,总员工数/2+1,以及总员工数/2+0.5

SQL语句:

select id,company,salary from 
(
select id,company,salary,
row_number() over(partition by company order by salary) as r,
count(id) over(partition by company) as c1 from Employee 
) a 
where r in (c1/2,c1/2+1,c1/2+0.5);

以上是关于LeetCode:Database 13.员工薪水中位数的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode(数据库)- 查询员工的累计薪水

LeetCode(数据库)- 员工薪水中位数

LeetCode(数据库)- 部门工资前三高的所有员工

LeetCode:Database 17.员工奖金

LeetCode:Database 42.项目员工 I

LeetCode:Database 44.项目员工 III