【MySQL】巧用 DATE_SUB 函数判断时间是否连续

力扣题

1、题目地址

1454. 活跃用户

2、模拟表

表 Accounts:

Column NameType
idint
namevarchar
  • id 是该表主键(具有唯一值的列)
  • 该表包含账户 id 和账户的用户名.

表 Logins:

Column NameType
idint
login_datedate
  • 该表可能包含重复项.
  • 该表包含登录用户的账户 id 和登录日期. 用户也许一天内登录多次.

3、要求

活跃用户 是指那些至少连续 5 天登录账户的用户。

编写解决方案, 找到 活跃用户 的 id 和 name。

返回的结果表按照 id 排序 。

结果表格式如下例所示。

示例 1:

输入:
Accounts 表:

idname
1Winston
7Jonathan

Logins 表:

idlogin_date
72020-05-30
12020-05-30
72020-05-31
72020-06-01
72020-06-02
72020-06-02
72020-06-03
12020-06-07
72020-06-10

输出:

idname
7Jonathan

解释:
id = 1 的用户 Winston 仅仅在不同的 2 天内登录了 2 次,所以,Winston 不是活跃用户.
id = 7 的用户 Jonathon 在不同的 6 天内登录了 7 次,6 天中有 5 天是连续的,所以,Jonathan 是活跃用户.

进阶问题:
如果活跃用户是那些至少连续 n 天登录账户的用户,你能否写出通用的解决方案?

4、代码编写

我的代码

逻辑是找到利用窗口函数,对不同 id 进行分组,再对各组里面的根据登录时间顺序排序,取前四天的时间到当前时间记录个数,只要个数满足大于等于 5 就满足条件,上面有说到 Logins 表是有可能出现重复的情况,所以需要提前去重。

SELECT DISTINCT two.id, three.name
FROM (SELECT *, COUNT(*) OVER (PARTITION BY id ORDER BY login_date range BETWEEN interval 4 day preceding AND current row) AS numFROM (SELECT DISTINCT id, login_date FROM Logins) AS one
) AS twoLEFT JOIN Accounts three USING(id)
WHERE num >= 5

网友代码(巧用 DATE_SUB 函数)

代码
SELECT DISTINCT Logins.id, Accounts.name
FROM (SELECT id, reference_dt, COUNT(1) cnt FROM (SELECT DISTINCT id, login_date, DATE_SUB(login_date, INTERVAL DENSE_RANK() OVER ( PARTITION BY id ORDER BY login_date ASC ) DAY) reference_dtFROM Logins) LoginsGROUP BY id, reference_dt
) LoginsINNER JOIN Accounts ON Logins.id = Accounts.id
WHERE cnt >= 5
ORDER BY id
代码分析

第一步:按 id 据 login_date 正序求 rank,这里用 DENSE_RANK()

SELECT DISTINCT id, login_date, DENSE_RANK() OVER ( PARTITION BY id ORDER BY login_date ASC ) rk 
FROM Logins

结果如下,这一步看不懂没关系,可直接看下一步。

| id | login_date | rk |
| -- | ---------- | -- |
| 1  | 2020-05-30 | 1  |
| 1  | 2020-06-07 | 2  |
| 7  | 2020-05-30 | 1  |
| 7  | 2020-05-31 | 2  |
| 7  | 2020-06-01 | 3  |
| 7  | 2020-06-02 | 4  |
| 7  | 2020-06-03 | 5  |
| 7  | 2020-06-10 | 6  |

第二步:用 login_date - rank,求出 reference_dt,reference_dt 相同的 login_date 即为连续的 login_date

SELECT DISTINCT id, login_date, DATE_SUB(login_date, INTERVAL DENSE_RANK() OVER ( PARTITION BY id ORDER BY login_date ASC ) DAY) reference_dt
FROM Logins

结果如下,很明显能看出不同 id 里面,只要 reference_dt 是相同的就一定代表 login_date 是连续的,之后我们只需要根据 id 和 reference_dt 进行分组,只要个数大于等于 5 就满足条件,查询出对应 id,再去连接 Accounts 查询其名字就可以

| id | login_date | reference_dt |
| -- | ---------- | ------------ |
| 1  | 2020-05-30 | 2020-05-29   |
| 1  | 2020-06-07 | 2020-06-05   |
| 7  | 2020-05-30 | 2020-05-29   |
| 7  | 2020-05-31 | 2020-05-29   |
| 7  | 2020-06-01 | 2020-05-29   |
| 7  | 2020-06-02 | 2020-05-29   |
| 7  | 2020-06-03 | 2020-05-29   |
| 7  | 2020-06-10 | 2020-06-04   |

DENSE_RANK 函数可参考:MYSQL 窗口函数(Rows & Range)—— 滑动窗口函数用法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/612068.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker安装nodejs,并更改为淘宝源

拉取官方 Node.js 镜像 docker pull node:latest创建 Dockerfile,并更改 NPM 下载源为淘宝源,设置为全局持久化 # 使用最新版本的Node.js作为基础镜像 FROM node:latest# 设置工作目录为/app WORKDIR /app # 更改 NPM 下载源为淘宝源,并设置…

c++学习笔记-STL案例-机房预约系统1-需求分析

1 机房预约系统需求 1.1 简单介绍 学校有几个规格不同的机房,由于使用经常出现“撞车”现象,现在开发一套预约系统,解决这一问题。 1.2 身份介绍 分别有三种身份使用该系统 学生代表:申请使用机房教师:审核学生的…

从单细胞数据分析的最佳实践看R与Python两个阵营的博弈

R与Python,在生物信息学领域的博弈异常激烈。许多生信分析,两个阵营都发展出了自己的方法,比如单细胞数据分析,R有Seurat,Python就有Scanpy。这些层出不穷的方法不断地吸引着吃瓜群众的眼球,同时也让人患上…

Qt 6之六:Qt Designer介绍

Qt 6之六:Qt Designer介绍 Qt Designer是一个可视化的用户界面设计工具,用于创建Qt应用程序的用户界面,允许开发人员通过拖放和布局来设计和创建GUI界面。 Qt 6之一:简介、安装与简单使用 https://blog.csdn.net/cnds123/articl…

Windows系统Copilot使用方案

在Windows环境中启用和使用Copilot的一般步骤和方案概述: 启用Windows Copilot 确保系统更新: 首先,您的设备需要运行最新的Windows 11版本,因为Copilot可能作为系统更新的一部分推出。 安装与激活: 如果Copilot是通过…

Linux 文件(夹)权限查看

命令 : ls -al ls -al 是一个用于列出指定目录下所有文件和子目录的命令,包括隐藏文件和详细信息。其中,-a 选项表示显示所有文件,包括以 . 开头的隐藏文件,-l 选项表示以列表的形式显示文件的详细信息。 本例中:drwxrwxr-x 为权限细节。 权限细节(Permission detail…

【UML】第18篇 组件图

目录 一、组件图的定义 二、组件图的作用 三、应用场景 四、构成 五、语法 一、组件图的定义 组件图(Component Diagram)是一种UML结构图,它展示了系统中组件、接口以及它们之间的关系。组件是代码的物理模块,如文件、库、可…

Vue3-47-Pinia-修改全局状态变量值的方式

说明 修改全局状态变量的值,是一个比较常规而且常见的操作。 本文就介绍四种常见的操作。 由于Option Store 和Setup Store 在修改的时候略有不同,所以本文也会将不同点体现一下。 全局状态变量的定义 包含了 Option Store 和Setup Store 两种定义方式&a…

设备树常用的其他 OF操作函数

一. 简介 前面几篇学习了设备树常用的 OF操作函数,文章地址如下: 设备树常用 OF 操作函数说明一-CSDN博客 设备树常用 OF 操作函数说明二-CSDN博客 本文继续学习设备树 常用的一些其他的 OF操作函数。 二. 设备树常用的其他 OF操作函数 下面学习设…

DePIN:重塑物理资源网络的未来

点击查看TechubNews更多相关推荐 一、DePIN:物理资源的新整合方式 Depin赛道的项目如雨后春笋般涌现,为市场注入了新的活力。作为先行者,Coinmanlabs已经深入布局Depin赛道,其中最引人注目的项目当属Grass。 什么是DePIN DePIN…

uniapp在web端怎么使用svg图标呢

在图标库中添加好项目用到的图标,点击symbol点击生成在线链接 点击生成的在线链接,此时会跳转到一个新窗口,是一个js文件 复制这个js文件的内容 然后在uniapp中新建svg.js文件,把从上面复制的代码粘贴到这个svg.js中 在main.js中引…

JAVA基础学习笔记-day16-网络编程

JAVA基础学习笔记-day16-网络编程 1. 网络编程概述1.1 软件架构1.2 网络基础 2. 网络通信要素2.1 如何实现网络中的主机互相通信2.2 通信要素一:IP地址和域名2.2.1 IP地址2.2.2 域名 2.3 通信要素二:端口号2.4 通信要素三:网络通信协议 3. 谈…

go 中的 fmt 占位符

通用占位符 %v 值的默认格式表示 fmt.Printf("%v\n", 100)}//100%v 类似%v,但输出结构体时会添加字段名 o : struct{ name string }{"tim"} fmt.Printf("%v\n", o)}} //{name:tim}%#v 值的 Go 语法表示 o : struct{ name stri…

0110qt

完善对话框,点击登录对话框,如果账号和密码匹配,则弹出信息对话框,给出提示"登录成功",提供一个Ok按钮,用户点击Ok后,关闭登录界面,跳转到其他界面 如果账号和密码不匹配&…

RK3568平台 平台总线模型Platform

一.平台总线模型介绍 编写了一个独立的驱动程序,但这样编写出来的驱动程序在重用性和可移植性上是很低的,无论之后要编写一个同类型的驱动还是将该驱动更换一个平台,都要花费时间重新修改驱动代码,而驱动的分离和分层这一软件思路…

Pytorch基础:数据读取与预处理——图像读取与存储

Pytorch基础:数据读取与预处理——图像读取与存储 1.读取图片2. 使用 matplotlib 库显示和保存图像 1.读取图片 图像库 opencv-python、imageio、PIL 等都具有图像读取的功能。 (base) PS C:\Users\阳> conda activate yang (yang) PS C:\Users\阳> python …

【angular教程240109】06 Angular父子组件以及非父子组件之间通讯

【angular教程240109】06 Angular父子组件以及组件之间通讯 目录: 【angular教程240109】06 Angular父子组件以及组件之间通讯一、子组件获取父组件的数据、执行子组件的方法 父组件给子组件传值-input1子组件 二、子组件通过Output 结合事件驱动实现组件通讯1 子组…

onlyOffice实践-在线协同word、ppt、excel编辑

一、x86 安装docker 18.09.0版本及以上(我的版本是18.09.0)配置docker阿里源,下载国外的镜像加速(参考docker的常规使用总结-CSDN博客)docker search 186184848/documentserver选择对应的破解版本下载(这个…

脚本编程游戏引擎会遇到哪些问题

在游戏开发中,脚本编程已经成为了一种非常常见的方式,用来实现游戏逻辑和功能。但是脚本编程游戏引擎也可能会面临一些挑战和问题。下面简单的探讨一下都会遇到哪些问题,并且该如果做。 性能问题 脚本语言通常需要运行时解释执行&#xff0…

Android 自动滚动的RecyclerView,手动滑动和自动滑动无缝斜街,手动滑动时数据不重复

概要 做一个自动滑动的列表,用于展示聊天记录或者通知栏信息等,还是使用主流的RecyclerView来做。网上有很多案例,但当手动滑动时会一直无限循环,数据重复的出现,如果想要自动滑动时能无限循环,手动滑动时又…