1890.(Easy)The Latest Login in 2020

表: 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 |
+---------+---------------------+

Result 表:
+---------+---------------------+
| 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.com/problems/the-latest-login-in-2020

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

Solution

窗口函数用魔怔了...

with t as (
    SELECT *
        , RANK() OVER (PARTITION BY user_id ORDER BY time_stamp DESC) rk
    FROM Logins
    WHERE LEFT(time_stamp,4)='2020'
)
SELECT user_id, time_stamp last_stamp
FROM t
WHERE rk=1
SELECT user_id, max(time_stamp) last_stamp
FROM Logins
WHERE LEFT(time_stamp,4)='2020'
GROUP BY user_id

Last updated