mysql 分组中位数

查询表中每个userid的loading_time 中位数

最终sql如下

set @ID1 = 0;
set @ID2 = 0;
select t2.userid,
       sum(if(t3.ID2=t2.id25, t3.loading_time, 0)) as t25,
       sum(if(t3.ID2=t2.id50, t3.loading_time, 0)) as t50,
       sum(if(t3.ID2=t2.id75, t3.loading_time, 0)) as t75
from (
    select userid,
     min(t.ID1) + round((max(t.ID1) - min(t.ID1)) / 4, 0) as id25,
     min(t.ID1) + round((max(t.ID1) - min(t.ID1)) / 2, 0) as id50,
     min(t.ID1) + round(3 * (max(t.ID1) - min(t.ID1)) / 4, 0) as id75
    from (
        select @ID1 := @ID1 + 1 as ID1, userid
        from matchinfo
        order by userid, loading_time
    ) as t
    group by userid
) as t2
left join (
    select @ID2 := @ID2 + 1 as ID2, userid, loading_time
    from matchinfo
    order by userid, loading_time
) as t3 on t2.userid=t3.userid and (t2.id25 = t3.ID2 or t2.id50 = t3.ID2 or t2.id75 = t3.ID2)
group by t2.userid;

查询结果

具体思路是

  1. 先将数据排序,然后每行添加递增序号ID1
  2. 算出每组ID1的中间值,这个中间值所在的行就对应了中位数
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值