较难等级的登陆日期确实都好难啊呜呜,此题虽说也是看解析做出来的,不过有明显感觉,有思路了:
题目要求查找每天登录的新用户的个数,首先,新用户就是登录日期最小的那个,选择出所有不重复的 date 作为新表,然后左连接通过 user_id 选出当前 user_id 最新登录的日子(也就是作为新用户的日子),此时,选出的 b.user_id 结果 如果不是空,说明他是第一次登录,此时新用户个数加一,老样子,此题需复盘
select a.date, count(b.user_id)
from (select distinct date from login) as a
left join (select user_id, min(date) as first_date from login group by user_id) as b
on a.date = b.first_date
group BY a.date
order by a.date