题解 | #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

全部评论

相关推荐

WillingLing:查看图片
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务