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