笔记(SQL练习)

该SQL查询用于计算每日登录用户的次日留存率。它首先找出每天的首次登录用户,然后通过LEFT JOIN找到这些用户次日是否再次登录。结果与没有当日新用户的日期合并,并按日期排序。次日留存率计算公式为:次日登录用户数 / 当日新用户数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

SELECT 
	a.date, 
	ROUND(COUNT(b.user_id) * 1.0/COUNT(a.user_id), 3) AS p
FROM (
    SELECT 
			user_id, 
			MIN(date) AS date
    FROM login
    GROUP BY user_id) a
LEFT JOIN login b
ON a.user_id = b.user_id
AND b.date = DATE_ADD(a.date,INTERVAL 1 DAY)
GROUP BY a.date
UNION
SELECT 
	date, 
	0.000 AS p
FROM login
WHERE date NOT IN (  -- 这是没有当日新用户(那么这天的次日转存率一定为0)
	SELECT 
		MIN(date)
    FROM login
    GROUP BY user_id)
ORDER BY date;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值