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

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

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

# 根据mindate 与 user_id 进行匹配
select round( (select count(*) from 
login l inner join 
(select user_id,min(date) date from login group by user_id) as h
on l.date = DATE_ADD(h.date,INTERVAL 1 DAY) and h.user_id=l.user_id)/(select count(distinct user_id) from login),3)

个人觉得比较直白的方法

1 查询第二天登录的人数

(select count(*) from

login l inner join

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

on l.date = DATE_ADD(h.date,INTERVAL 1 DAY) and h.user_id=l.user_id)

2 查询总人数

(select count(distinct user_id) from login)

3 最后根据round 四舍五入到后三位小数

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

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