题解 | SQL29 计算用户的平均次日留存率

这道题明显难度上来了。

我们需要记录下所有刷题了的用户的数量,我们不关心他当天刷了多少题,只要他刷了题,我们就要统计进去。接着我们需要知道每个用户他在下一天是否也刷了题,所以要拿到一个用户刷了题的天数+1,看看存不存在。

上面的思路自然会让我们想到需要两张表连接起来,一个表看前一天的,一个表看后一天的。所以,我们用left join把左边的表看作为前一天的用户数量,而右边的表看作后一天的用户留存的数量。这样分开之后,思路就更清晰了。

这里,我们还需要知道使用DATE_ADD(date, interval expression)函数。

select 
    count(q2.device_id) / count(q1.device_id) as avg_ret
from
    (select distinct device_id, date from question_practice_detail) as q1
left join
    (select distinct device_id, date from question_practice_detail) as q2
on q1.device_id = q2.device_id and q2.date = DATE_ADD(q1.date, interval 1 day);

全部评论

相关推荐

用户64975461947315:这不很正常吗,2个月开实习证明,这个薪资也还算合理,深圳Java好多150不包吃不包住呢,而且也提前和你说了没有转正机会,现在贼多牛马公司骗你说毕业转正,你辛辛苦苦干了半年拿到毕业证,后面和你说没hc了😂
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务