题解 | #牛客每个人最近的登录日期(三)#
牛客每个人最近的登录日期(三)
http://www.nowcoder.com/practice/16d41af206cd4066a06a3a0aa585ad3d
先挑选出来用户第一天登录的
然后尝试去join用户第二天登录的记录,如果没有就会是None
最后count列名会数非None的个数,count(1)会数记录数
select round(count(l.date)/count(1),3) from (select user_id, min(date) as first_date from login group by user_id) tmp left join login l on tmp.user_id=l.user_id and date_add(tmp.first_date,INTERVAL 1 DAY) = l.date;

查看10道真题和解析