题解 | 牛客每个人最近的登录日期(五)

牛客每个人最近的登录日期(五)

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

select distinct
    date,
    round(if (p is null, 0, p), 3)
from
    login login1
    left join (
        select
            fdate,
            count(date) / count(fdate) p
        from
            (
                select
                    user_id,
                    min(date) fdate,
                    date_add(min(date), interval 1 day) sdate
                from
                    login
                group by
                    user_id
            ) as t1
            left join login on t1.user_id = login.user_id
            and t1.sdate = login.date
        group by
            fdate
    ) as t2 on login1.date = t2.fdate
order by
    date

表连接加到厌倦,先想办法算出p,然后连接日期就好了

全部评论

相关推荐

迟缓的马里奥求你们别...:我双2,FPGA方向,在成都找工作投了上百家,收到面试的不超过10家,是成都这个地方太有说法了。西南柬埔寨
秋招,不懂就问
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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