题解 | #牛客每个人最近的登录日期(三)#

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

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

1.将第二天日期拼到表后

select *,date_add(min(date) over (partition by user_id),interval 1 day) d from login

2.筛选在第二天登陆的新用户

select *
from (select *,date_add(min(date) over (partition by user_id),interval 1 day) d from login) l
where date=d

3.计算所有用户数量

select count(distinct user_id) from login)

4.p=在第二天登陆的新用户/所有用户

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) d from login) l
where date=d

全部评论

相关推荐

不知道怎么取名字_:玩游戏都写到简历上了啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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