262题解 | 利用窗口函数解题

牛客每个人最近的登录日期(三)

https://www.nowcoder.com/practice/16d41af206cd4066a06a3a0aa585ad3d

step 1:利用窗口函数找到各自user_id对应的第二天登陆时间

select *
,date_add(min(date) over(partition by user_id),interval 1 day) d2 --d2表示第二天登陆时间
from login

step 2:找到每个user_id下,date 与第二天登陆时间d2相等的user_id即为留存成功

select count(*)
from (
    select *
    ,date_add(min(date) over(partition by user_id),interval 1 day) d2
    from login
) a
where d2=date

step3:求user_id数

--不能group by之后利用count求和
--此时得到的是:依据不同user_id分组后,各个组内的行数
--得到的结果是向量,让我反应过来不对
select count(*)
from login
group by user_id


--正确求user_id数的方法
select count(distinct user_id)
from login

step4:合并代码块,最终结果

select round(count(*)/(select count(distinct user_id) from login), 3)
from (
    select *
    ,date_add(min(date) over(partition by user_id),interval 1 day) d2
    from login
) a
where d2=date

全部评论

相关推荐

2025-12-19 15:04
门头沟学院 Java
小肥罗:hr爱上你了,你负责吗哈哈
点赞 评论 收藏
分享
2本硕,在这一个下午真的绷不住了,浪费了太多时间,现在的技术栈还停在C语言和stm32上,找嵌入式的实习面试被拷打,找杭州的一个也找不到,真的心里难受,linux没学过,研二了开始慌了。
一条淡水魚:嵌入式这行的面试我认为实际项目比较重要,技术栈简单的提一嘴就行,面试官在乎的关键点在于你用了这些技术做了哪些工作解决了什么问题,而不是停留在离散的那些个技术栈上,那除了教课没有意义,好比你提到的c语言和32,你用32做过哪些具体的项目?接触过什么外设?使用过哪些公司的SDK?有没有实际产品落地?以及各种只有进入真正的生产环节当中才会积累到的经验......主动去和面试官讨论这些实际的问题,甚至还能就某个具体参数的合理性与他去简单探讨一下,只要技术栈对口,基本上就稳啦~(另外linux和RTOS是嵌入式的标配哦,选一个方向走下去吧)
点赞 评论 收藏
分享
评论
点赞
2
分享

创作者周榜

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