题解 | #2021年11月每天新用户的次日留存率#
2021年11月每天新用户的次日留存率
https://www.nowcoder.com/practice/1fc0e75f07434ef5ba4f1fb2aa83a450
# 首先用union解决跨天问题,然后开窗记录下一个登录日 WITH t1 AS ( SELECT uid ,DATE(in_time) AS dt FROM tb_user_log UNION SELECT uid ,DATE(out_time) AS dt FROM tb_user_log ), t2 AS ( SELECT uid ,dt ,LEAD(dt) OVER (PARTITION BY uid ORDER BY dt) next_day FROM t1 ) SELECT dt ,ROUND(AVG(CASE WHEN DATEDIFF(next_day, dt) = 1 THEN 1 ELSE 0 END), 2) AS uv_left_rate FROM t2 a # 这里要注意,不能直接在上面把10月筛选掉,会影响11.01这一天的判断,要在这里把10月的记录筛掉 # 同时利用not exists筛掉非新用户 WHERE NOT EXISTS (SELECT 1 FROM t2 b WHERE a.uid = b.uid AND a.dt > b.dt) AND DATE_FORMAT(dt, '%Y%m') = '202111' GROUP BY dt ORDER BY dt