力扣-2020年最后一次登录

本文介绍了如何使用SQL查询找出在2020年登录过的用户在当年的最后一次登录时间。文章提供了四种正确解答方法,包括通过限制时间戳年份、分组和取最大时间戳,以及使用排名函数rank()、dense_rank()和row_number()来获取每个用户最新的2020年登录记录。
摘要由CSDN通过智能技术生成

大家好,我是空空star,本篇带大家了解一道简单的力扣sql练习题。


前言


一、题目:1890. 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 |
+---------+---------------------+
输出:
+---------+---------------------+
| 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.正确示范①

提交SQL

select user_id,max(time_stamp) last_stamp
from Logins
where year(time_stamp)=‘2020’
group by user_id;
或者
select user_id,max(time_stamp) last_stamp
from Logins
where substr(time_stamp,1,4)=‘2020’
group by user_id;

运行结果

2.正确示范②

提交SQL

select user_id,time_stamp last_stamp from(
select user_id,time_stamp,
rank() over(partition by user_id order by time_stamp desc) col
from Logins
where year(time_stamp)=‘2020’
) u
where u.col=1;

运行结果

3.正确示范③

提交SQL

select user_id,time_stamp last_stamp from(
select user_id,time_stamp,
dense_rank() over(partition by user_id order by time_stamp desc) col
from Logins
where year(time_stamp)=‘2020’
) u
where u.col=1;

运行结果

4.正确示范④

提交SQL

select user_id,time_stamp last_stamp from(
select user_id,time_stamp,
row_number() over(partition by user_id order by time_stamp desc) col
from Logins
where year(time_stamp)=‘2020’
) u
where u.col=1;

运行结果

5.其他


总结

正确示范①思路:
通过year(time_stamp)='2020'限定2020年的登录用户,
按照user_id分组group by user_id,取最大time_stampmax(time_stamp)
正确示范②思路:
通过year(time_stamp)='2020'限定2020年的登录用户,
通过rank() over(partition by user_id order by time_stamp desc) col
取排名1;
正确示范③思路:
通过year(time_stamp)='2020'限定2020年的登录用户,
通过dense_rank() over(partition by user_id order by time_stamp desc) col
取排名1;
正确示范④思路:
通过year(time_stamp)='2020'限定2020年的登录用户,
通过row_number() over(partition by user_id order by time_stamp desc) col
取排名1。


  • 12
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 21
    评论
评论 21
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

空空star

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值