Leetcode数据库题目-569.员工薪水中位数

参考了这个mysql_如何用mysql计算每组的中位数

题目描述:
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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 9,778评论 0 44
  • 今天看到一位朋友写的mysql笔记总结,觉得写的很详细很用心,这里转载一下,供大家参考下,也希望大家能关注他原文地...
    信仰与初衷阅读 4,750评论 0 30
  • 现在社交圈越来越多自媒体人,也有越来越多的社交平台渗透到生活中,偶尔会觉得这些到处都是的“杂乱信息”占据了自己不少...
    恰逢花开_Feiyu阅读 293评论 0 0
  • 写在前面:关于周记复盘,加入108行动营后写了2篇体验周记,可以说体验一下周记的幸福啊,而这篇3th才算是周记闯关...
    敏大文阅读 892评论 0 1
  • 越来越多的人问我:“市面上那么多的艾条,我为什么一定要买艾江山的艾条呢?”那么我来反问您一句,艾自己,不用世界艾草...
    ai无所谓阅读 183评论 0 0