首页 > 试题广场 >

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

[编程题]牛客每个人最近的登录日期(四)
  • 热度指数:134587 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 256M,其他语言512M
  • 算法知识视频讲解
牛客每天有很多人登录,请你统计一下牛客每个日期登录新用户个数,
有一个登录(login)记录表,简况如下:
id
user_id client_id
date
1 2 1 2020-10-12
2 3 2 2020-10-12
3 1 2 2020-10-12
4 2 2 2020-10-13
5 1 2 2020-10-13
6 3 1 2020-10-14
7 4 1 2020-10-14
8 4 1 2020-10-15
第1行表示user_id为2的用户在2020-10-12使用了客户端id为1的设备登录了牛客网,因为是第1次登录,所以是新用户
。。。
第4行表示user_id为2的用户在2020-10-13使用了客户端id为2的设备登录了牛客网,因为是第2次登录,所以是老用户
。。
最后1行表示user_id为4的用户在2020-10-15使用了客户端id为1的设备登录了牛客网,因为是第2次登录,所以是老用户


请你写出一个sql语句查询每个日期登录新用户个数,并且查询结果按照日期升序排序,上面的例子查询结果如下:

date
new
2020-10-12
3
2020-10-13
0
2020-10-14
1
2020-10-15
0
查询结果表明:
2020-10-12,有3个新用户(user_id为2,3,1)登录
2020-10-13,没有新用户登录
2020-10-14,有1个新用户(user_id为4)登录
2020-10-15,没有新用户登录

示例1

输入

drop table if exists login;
CREATE TABLE `login` (
`id` int(4) NOT NULL,
`user_id` int(4) NOT NULL,
`client_id` int(4) NOT NULL,
`date` date NOT NULL,
PRIMARY KEY (`id`));

INSERT INTO login VALUES
(1,2,1,'2020-10-12'),
(2,3,2,'2020-10-12'),
(3,1,2,'2020-10-12'),
(4,2,2,'2020-10-13'),
(5,1,2,'2020-10-13'),
(6,3,1,'2020-10-14'),
(7,4,1,'2020-10-14'),
(8,4,1,'2020-10-15');

输出

2020-10-12|3
2020-10-13|0
2020-10-14|1
2020-10-15|0
头像 牛客题解官
发表于 2025-03-18 17:34:56
精华题解 这道题目要求我们统计每个日期的新用户登录数量。我们要做的事情如下: 1. 确定总体问题 我们需要统计每个日期的新用户登录数量,新用户定义为在某个日期首次登录的用户。即从登录记录表中提取数据,使用窗口函数ROW_NUMBER来标记每个用户的首次登录记录,然后按日期分组统计新用户的数量,并按日期升序排序 展开全文
头像 qstalking
发表于 2021-01-26 11:29:36
#明确问题:登录的当前日期=该用户所有登录日期的最小值 select date         ,count(distinct case when (user_id,date) in     (select user_id,min 展开全文
头像 马小舍
发表于 2020-12-12 18:52:12
提供另一种解法: 先得到所有日期表select distinct date from login; 然后左连接新用户首次登陆的日期表(select user_id, min(date) first_date from login group by user_id); 归类统计日期出现的次数. M 展开全文
头像 SunburstRun
发表于 2020-08-20 14:56:37
这个题目做过前面的题的话,应该可以比较容易就知道, select l1.date,count(distinct l1.user_id) from login l1 group by l1.date; 这样可以得到每个日期里面,用户登录的 展开全文
头像 高质量搬砖人
发表于 2021-02-01 11:19:19
方法)一开始是这样写的 SELECT date, COUNT(user_id) FROM login WHERE (date, user_id) IN( SELECT MIN(date), user_id FROM login GROUP BY user_id ) GROUP 展开全文
头像 此用户名涉嫌违规
发表于 2021-04-01 11:20:31
题目描述:sql语句查询每个日期登录新用户个数,并且查询结果按照日期升序排序。个人思路:new_user找出新用户的id和首登陆日。使用login left join new_user这样当有一天没有新用户时new_user表对应的null,null。因为count(null)=0,所以当日没有用户 展开全文
头像 109号
发表于 2020-12-07 12:12:53
两种解法: 使用count计算每日新用户个数 使用case和窗口函数计算每个用户的登陆次数序号,选取第一次登陆的计数 使用count计算每日新用户个数时,要注意不能遗漏新用户个数为0的日期,可以使用union补充上 SELECT l.mdate AS date,COUNT(user_id) AS 展开全文
头像 Num57.
发表于 2021-02-09 21:54:41
忽略了统计数为0的情况(错误写法) -- 构造出一个新的表,以用户ID分组,然后过滤出每组中最小的日期 -- 根据上表然后在进行统计 -- 出现的问题:没法统计新用户为0的日期 select `new_login`.`date`,count(`new_login`.`id`) as `new` fr 展开全文
头像 德布罗意波不长
发表于 2024-02-21 17:52:25
提供一个用OVER()和PARTITION的解法,好像还没有人这么写,非常简单方便, 只要9行思路:做一个FROM 的subquery,目的是能够让所有第一次登陆的新用户的排名是1,后期用来筛选:用窗口函数,按照user_id分组,按照日期升序排序。按照日期分组,并计算不同日期下排名为1的行数之和 展开全文
头像 Ding_123
发表于 2021-12-07 15:50:55
知识点 建立窗口函数排序作为一个新表,然后按照日期进行分组。因为有可能同一人在一天内用不同设备多次登录的情况,所以排序使用row——number只会出现一个1 一开始想的是计数count,但是当天没有新用户会直接没有记录,所以使用case when然后使用sum进行计数 需要注意的小细节就是每一个 展开全文
头像 udad
发表于 2021-11-29 15:59:54
select date, sum(     case     when (user_id, date) in (select user_id, min(date) from login group by user_id) 展开全文