写点什么

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

作者:知心宝贝
  • 2022 年 7 月 14 日
  • 本文字数:962 字

    阅读完需:约 3 分钟

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

一、问题描述

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 Loginswhere year(time_stamp)=2020group by user_id
复制代码

五、测试结果




发布于: 刚刚阅读数: 3
用户头像

知心宝贝

关注

公众号:穿越计算机的迷雾 2022.03.07 加入

生于尘埃 溺于人海 死于理想高台

评论

发布
暂无评论
数据库每日一题---第22天:最后一次登录_数据库_知心宝贝_InfoQ写作社区