查询各个岗位分数升序排列之后的中位数位置的范围floor()

考试分数(四)

https://www.nowcoder.com/practice/502fb6e2b1ad4e56aa2e0dd90c6edf3c

/*1、case when语句,较为繁琐
with t as(
    select *,
        row_number() over(partition by job order by score) rk
    from grade
)

select job,
    case when mod(max(rk),2)=0 then round(max(rk)/2,0)
         when mod(max(rk),2)=1 then round((max(rk)+1)/2)
    end start,
    case when mod(max(rk),2)=0 then round(max(rk)/2+1)
         when mod(max(rk),2)=1 then round((max(rk)+1)/2)
    end end
from t
group by job
order by job

2、floor(x) 返回等于或小于x的最大整数;
ceil(x) 返回大于或等于x的最大整数
*/
select job,
    floor((count(score)+1)/2) as start,
    floor((count(score)+2)/2) as end
from grade
group by job
order by job

全部评论

相关推荐

快刀斩offer:干测试,项目组就我一个测试,准备在职考研跑路了
点赞 评论 收藏
分享
在笔试的大西瓜很矫健:校招数分不用想了,这经历和学历都不够用,大厂更别想,初筛都过不了,说点不好听的小厂数分都进不去(小厂也是假数分),要两个对口实习+3个项目(或者3+2),而且要有含金量才能补一点你的学历劣势。 建议刷实习,社招找数分,校招看运气,能入行业就行,可以运营转数分
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务