题解 | 最长连续登录天数

最长连续登录天数

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

with t1 as 
(
    select 
    user_id,
    row_number() over(partition by user_id order by fdate) as rk,
    date_sub(fdate, interval (row_number() over(partition by user_id order by fdate)) day) as ori_date
    from tb_dau
    where fdate between '2023-01-01' and '2023-12-31'
)
,
t2 as 
(
select 
user_id,
count(user_id) as consec_days
from t1
group by user_id,ori_date
)

select 
user_id,
max(consec_days) as max_consec_days
from
t2
group by 
user_id

全部评论

相关推荐

点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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