题解 | #获得积分最多的人(三)#

获得积分最多的人(三)

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

with
    t1 as (
        select
            b.user_id,b.type type ,
            grade_num - coalesce(
                lead (grade_num, 1) over (
                    partition by
                        user_id
                    order by
                        type
                ),
                0
            ) num
        from
            (
                select
                    user_id,
                    type,
                    sum(grade_num) grade_num
                from
                    grade_info a
                group by
                    user_id,
                    type
            ) b
    )
        
        select c.id,d.name,c.grade_num
        from
        (
        select
            t1.user_id id,
            t1.num grade_num,
            rank() over( order by t1.num desc) rn
        from t1 
        where t1.type='add'
        )c
        left join user d
        on c.id=d.id
        where c.rn=1
        order by c.id


全部评论

相关推荐

昨天 16:08
门头沟学院 运营
点赞 评论 收藏
分享
天天困啊:个人建议第一点就是熟悉Redis这里不要这么写,写上Redis比较核心的技术,什么缓存一致性,雪崩穿透击穿那些,掌握cos其实不用写在专业技能里这个你做了鱼皮的这个项目面试官默认应该认为你应该懂了,鱼皮这个项目核心挺多建议多啃啃,在做一个鱼皮的微服务项目俩项目在一起比较好哦
你的简历改到第几版了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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