题解 | #考试分数(五)#

考试分数(五)

https://www.nowcoder.com/practice/b626ff9e2ad04789954c2132c74c0513

select
id
,table1.job
,score
,rank1 t_rank
from
(
select
id
,job
,score
,row_number()over(partition by job order by score desc) rank1
from grade
)table1
left join
(
SELECT 
job
,floor(( count(*) + 1 )/ 2 ) AS "start"
,floor(( count(*) + 2 )/ 2 ) AS 'end' 
FROM grade 
GROUP BY job 
)table2
on table1.job = table2.job
where rank1 = start or rank1 = end
order by 1

全部评论

相关推荐

投递北京经纬恒润科技股份有限公司等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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