LeetCode数据库---1890. 2020年最后一次登录
题目:
表: Logins +----------------+----------+ | 列名 | 类型 | +----------------+----------+ | user_id | int | | time_stamp | datetime | +----------------+----------+ (user_id, time_stamp) 是这个表的主键。 每一行包含的信息是user_id 这个用户的登录时间。 编写一个 SQL 查询,该查询可以获取在 2020 年登录过的所有用户的本年度 最后一次 登录时间。结果集 不 包含 2020 年没有登录过的用户。 返回的结果集可以按 任意顺序 排列。 查询结果格式如下例。 示例 1: 输入: 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年没有登录,所以结果集不应包含。 来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/the-latest-login-in-2020/
知识点:
1. 日期函数
一些重要的MySQL内置的日期函数:
NOW() 返回当前日期和时间。
CURDATE() 返回当前日期。
CURTIME() 返回当前时间
DATE() 提取日期或日期时间表达式的日期部分。
DAY() 返回月份中的一天(0-31)。
DAYNAME() 返回工作日的名称。
MONTH() 返回经过日期(1-12)的月份。
MONTHNAME() 返回月份的名称。
YEAR() 返回年份。
DATE_FORMAT() 以其他格式显示日期和时间值。
EXTRACT() 提取日期的一部分。
DATE_ADD() 将指定的时间值(或间隔)添加到日期值。
DATE_SUB() 从日期值中减去指定的时间值(或间隔)。
DATEDIFF() 返回两个日期之间的天数
select user_id, max(time_stamp) last_stamp from Logins where year(time_stamp) = 2020 group by user_id;
IN A WORLD LIKE THIS
萬物之中,希望至美;至美之物,永不凋零