题解 | #最长连续登录天数#

最长连续登录天数

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

SELECT 
	user_id,
    MAX(连续登录天数) AS max_consec_days
FROM
	-- 第二张子表:根据初始起始天数进行分组,分别计算该月内的连续登录时间
	(SELECT 
		user_id,
		MAX(日期排序) - MIN(日期排序) + 1 AS 连续登录天数
	FROM
	 -- 第一张子表:若两行登陆日期-序号相同则证明这两行是连续的两天,并且能得到两行的相同的起始天数
		(SELECT user_id,
			fdate,
			ROW_NUMBER() OVER(PARTITION BY user_id ORDER BY fdate) AS 日期排序,
			DATE_SUB(fdate, INTERVAL ROW_NUMBER() OVER(PARTITION BY user_id ORDER BY fdate) DAY) AS 初始日期
		FROM tb_dau
		WHERE fdate BETWEEN '2023-01-01' AND '2023-01-31') AS t1
	GROUP BY user_id, 初始日期) AS t2
GROUP BY user_id;

全部评论

相关推荐

程序员花海:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
秋招吐槽大会
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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