题解 | 最长连续登录天数

SELECT 
	DISTINCT user_id,
	max(max_consec_days) as max_consec_days
FROM 
(
	SELECT user_id,
		count(date) as max_consec_days
	FROM
	(	
		SELECT *,
			DATE_SUB(fdate,INTERVAL date_order day) as date
		from
		(
			SELECT 
				DISTINCT *,
				ROW_NUMBER() OVER(PARTITION BY user_id ORDER BY fdate) AS date_order
			FROM tb_dau
			where 
				fdate between '2023-01-01' and '2023-01-31'
		) as t1
	) as t2
	GROUP BY user_id,date 
) as t3 
GROUP BY user_id

全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 18:19
个个985的硕士闭着眼睛都有15k以上的月薪,天天嚷嚷着研究生白度读了,天天嚷嚷着反向读研了........
MMMJC:不读研22本科出去的基本都拿28k呢,你不能用25的研究生和25的本科生比然后说没反向读研,而是25研和22本比呀
点赞 评论 收藏
分享
_mos_:忍耐王
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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