leetcode569. 员工薪水中位数

Employee 表包含所有员工。Employee 表有三列:员工Id,公司名和薪水。

+-----+------------+--------+
|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     |
+-----+------------+--------+

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

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

 

select
    company_rownumber.Id as Id,
    company_rownumber.Company as Company,
    company_rownumber.Salary as Salary
from
#第一部分算row_number,每个公司内部的排序
(select
    Id,
    Company,
    Salary,
    @company_no:=case when @company_name = company then @company_no+1 else 1 end as company_no,
    @company_name:=company
from
    (select id,company,salary from employee,(select @company_no:=0,@company_name:="") b) c
order by 
    Company,
    Salary) company_rownumber
join
#第二部分算每个公司总共有多少个
(select
    info.Id,
    info.Company,
    info.Salary,
    cnt
from
(select
    Id,
    Company,
    Salary
from
    Employee) info
join
(select
    Company,
    count(1) as cnt
from
    Employee
group by
    Company) company_cnt
on
    info.Company = company_cnt.Company) company_group_cnt
on
    company_rownumber.Id = company_group_cnt.Id
#限定每个公司的row_number在总数的一半的区间里
where
    company_no >= cnt/2 
    and company_no <= cnt/2+1

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值