题解 | 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);

全部评论

相关推荐

在喝茶的牛油很喜欢吃...:今天oc了
点赞 评论 收藏
分享
程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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