题解 | #查询连续登陆的用户#

查询连续登陆的用户

https://www.nowcoder.com/practice/9944210610ec417e94140ac09512a3f5

select
    tt.user_id
from
    (select
        t.user_id,
        t.start_date,
        max(date_rank) - min(date_rank) + 1 as days
    from
        (select
            rt.user_id,
            date(lt.log_time) as log_date,
            row_number() over(partition by rt.user_id order by date(lt.log_time)) as date_rank,
            date_sub(date(lt.log_time),interval row_number() over(partition by rt.user_id order by date(lt.log_time)) day) as start_date
        from
            register_tb rt
        join 
            login_tb lt on rt.user_id = lt.user_id) t
    group by 
        1,2   ) tt
where
    days >= 3 

全部评论

相关推荐

屌丝逆袭咸鱼计划:心态摆好,man,晚点找早点找到最后都是为了提升自己好进正职,努力提升自己才是最关键的😤难道说现在找不到找的太晚了就炸了可以鸡鸡了吗😤早实习晚实习不都是为了以后多积累,大四学长有的秋招进的也不妨碍有的春招进,人生就这样
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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