当前位置:网站首页>数据库每日一题---第22天:最后一次登录

数据库每日一题---第22天:最后一次登录

2022-07-07 21:49:00 InfoQ


一、问题描述

: 
Logins

+----------------+----------+
| 列名 | 类型 |
+----------------+----------+
| user_id | int |
| time_stamp | datetime |
+----------------+----------+
(user_id, time_stamp) 是这个表的主键。
每一行包含的信息是user_id 这个用户的登录时间。

编写一个 
SQL
 查询,该查询可以获取在 
2020
 年登录过的所有用户的本年度 最后一次 
登录时间
。结果集 不 包含 
2020
 年没有登录过的用户。

返回的结果集可以按 
任意顺序
 排列。

查询结果
格式如下例:

题目链接
最后一次登录

二、题目要求

样例

输入:
Logins 表:
+---------+---------------------+
| user_id | time_stamp |
+---------+---------------------+
| 6 | 2020-06-30 15:06:07 |
| 6 | 2021-04-21 14:06:06 |
| 6 | 2019-03-07 00:18:15 |
| 8 | 2020-02-01 05:10:53 |
| 8 | 2020-12-30 00:46:50 |
| 2 | 2020-01-16 02:49:50 |
| 2 | 2019-08-25 07:59:08 |
| 14 | 2019-07-14 09:00:00 |
| 14 | 2021-01-06 11:59:59 |
+---------+---------------------+
输出:
+---------+---------------------+
| user_id | last_stamp |
+---------+---------------------+
| 6 | 2020-06-30 15:06:07 |
| 8 | 2020-12-30 00:46:50 |
| 2 | 2020-01-16 02:49:50 |
+---------+---------------------+
解释:
6号用户登录了3次,但是在2020年仅有一次,所以结果集应包含此次登录。
8号用户在2020年登录了2次,一次在2月,一次在12月,所以,结果集应该包含12月的这次登录。
2号用户登录了2次,但是在2020年仅有一次,所以结果集应包含此次登录。
14号用户在2020年没有登录,所以结果集不应包含。

考察

1.聚合函数
2.建议用时10~25min

三、问题分析

题目要求我们求出
2020
年最后一次登录的用户,其中用户一年内可能会登录若干次,我们只需要找出
2020
年最大的日期。

对于这一题,聚合函数分组依然能够解决问题,我们按照用户的编号进行分组,分组之后的每个编号数据包含登录的日期,这时候我们使用
max
函数直接求解最大的日期就行了。

四、编码实现

select user_id, max(time_stamp) as 'last_stamp'
from Logins
where year(time_stamp)=2020
group by user_id

五、测试结果

null
null
null
原网站

版权声明
本文为[InfoQ]所创,转载请带上原文链接,感谢
https://xie.infoq.cn/article/89bf2314346fc154e8f392b2d