牛客SQL练习第70题
程序员文章站
2022-06-07 11:43:16
...
题目描述
牛客每天有很多人登录,请你统计一下牛客每个日期登录新用户个数,
有一个登录(login)记录表,简况如下:
第1行表示id为2的用户在2020-10-12使用了客户端id为1的设备登录了牛客网,因为是第1次登录,所以是新用户
。。。
第4行表示id为2的用户在2020-10-13使用了客户端id为2的设备登录了牛客网,因为是第2次登录,所以是老用户
。。
第4行表示id为4的用户在2020-10-15使用了客户端id为1)的设备登录了牛客网,因为是第2次登录,所以是老用户
请你写出一个sql语句查询每个日期登录新用户个数,并且查询结果按照日期升序排序,上面的例子查询结果如下:(输出0,可以用sqlite的ifnull函数尝试实现,select ifnull(null,1)的输出是1)
查询结果表明:
2020-10-12,有3个新用户(id为2,3,1)登录
2020-10-13,没有新用户登录
2020-10-14,有1个新用户(id为4)登录
2020-10-15,没有新用户登录
解答:
先找出用户第一次登陆的日期,将其左连接关联到日期表,就能得到每天的新用户,分组计数即可。
select a.all_date as date, ifnull(count(b.user_id),0) as new
from
(select distinct(date) as all_date
from login) as a
left join
(select user_id, min(date) as reg_date
from login
group by user_id) as b
on a.all_date = b.reg_date
group by a.all_date
上一篇: 牛客SQL练习第67题