浅析一下目前牛客网最难的一道SQL题

本文详细分析了牛客网上一道最具挑战性的SQL题目,涉及如何计算每个日期的新用户次日留存率。在解决过程中,强调了正确处理日期覆盖和新用户定义的重要性,以及在SQL查询中使用LEFT JOIN、CASE WHEN和DATEDIFF函数的技巧。最终,给出了完整的SQL解决方案,包括使用COUNT(DISTINCT)避免重复计算,以及ROUND和IFNULL函数来处理小数和非空限制,确保结果准确。
摘要由CSDN通过智能技术生成

在这里插入图片描述
如图所示,牛客每个人最近的登录日期(五) 此题以通过率来看可以算是目前最难的一道题。
我在做的过程中也是卡了挺久的,但最终在其他答案的点拨下做出来了。
题所给的login表
在这里插入图片描述
在这里插入图片描述
请你写出一个sql语句查询每个日期新用户的次日留存率,结果保留小数点后面3位数(3位之后的四舍五入),并且查询结果按照日期升序排序。
次日新用户的留存率=次日留存的人数/总的新用户数
1.先求出所有日期的新用户

 select user_id,min(date) as date
    from login
    group by user_id

在这里插入图片描述

2.求留存率的一般做法是利用 新用户及日期 left join on a.user_id=b.user_id 就会是 左边 uid 和最小日期 右边就是 uid和所有日期 这时候用case when +datediff()=1函数 就可以求出次日登录的记录
但这个方法并不通用 要求 新用户及日期需要覆盖所有日期 如 牛客每个人最近的登录日期(三)题中就可以这样做 因为新用户的日期刚好覆盖了所有的日期 此题并非如此 所以需要加上一个日期使其变成 题(三)类似的情形

在这里插入图片描述

加上一列时间

select * from (
 select date
    from login
    group by date
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值