MySQL查询连续n天登录的用户的方法

作者:admin 发布时间:2023-02-15 16:25:24 浏览:576次

这篇文章介绍了SQL查询至少连续n天登录用户的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

以连续3天为例,使用工具:MySQL。

1.创建SQL表:




create table if not exists orde(id varchar(10),date datetime,orders varchar(10)); 
insert into orde values('1' , '2019/1/1',10 ); 
insert into orde values('1' , '2019/1/2',109 ); 
insert into orde values('1' , '2019/1/3',150 ); 
insert into orde values('1' , '2019/1/4',99); 
insert into orde values('1' , '2019/1/5',145); 
insert into orde values('1' , '2019/1/6',1455); 
insert into orde values('1' , '2019/1/7',199); 
insert into orde values('1' , '2019/1/8',188 ); 
insert into orde values('4' , '2019/1/1',10 ); 
insert into orde values('2' , '2019/1/2',109 ); 
insert into orde values('3' , '2019/1/3',150 ); 
insert into orde values('4' , '2019/1/4',99); 
insert into orde values('5' , '2019/1/5',145); 
insert into orde values('6' , '2019/1/6',1455); 
insert into orde values('7' , '2019/1/7',199); 
insert into orde values('8' , '2019/1/8',188 ); 
insert into orde values('9' , '2019/1/1',10 ); 
insert into orde values('9' , '2019/1/2',109 ); 
insert into orde values('9' , '2019/1/3',150 ); 
insert into orde values('9' , '2019/1/4',99); 
insert into orde values('9' , '2019/1/6',145); 
insert into orde values('9' , '2019/1/9',1455); 
insert into orde values('9' , '2019/1/10',199); 
insert into orde values('9' , '2019/1/13',188 ); 


查看数据表:

MySQL查询连续n天登录的用户的方法

2.使用row_number() over() 排序函数计算每个id的排名,SQL如下:

select *,row_number() over(partition by id order by date ) 'rank' 
from orde 
where orders is not NULL; 


查看数据表:

MySQL查询连续n天登录的用户的方法

3.将date日期字段减去rank排名字段,SQL如下:

select *,DATE_SUB(a.date,interval a.rank day) 'date_sub' 
from( 
select *,row_number() over(partition by id order by date ) 'rank' 
from orde 
where orders is not NULL 
) a; 


查看数据:

MySQL查询连续n天登录的用户的方法

4.根据id和date分组并计算分组后的数量(count)、计算最早登录和最晚登录的时间,SQL如下:

select b.id,min(date) 'start_time',max(date) 'end_time',count(*) 'date_count' 
from( 
select *,DATE_SUB(a.date,interval a.rank day) 'date_sub' 
from( 
select *,row_number() over(partition by id order by date ) 'rank' 
from orde 
where orders is not NULL 
) a 
) b 
group by b.date_sub,id 
having count(*) >= 3 
; 


查看数据:

MySQL查询连续n天登录的用户的方法

如需转载请保留本文出处: https://www.zhe94.com/942.html

上一篇:mysql 复制表和表数据的方法
下一篇:MySql中group_concat字符长度限制1024怎么办
MySQL-窗口函数有哪些

MySQL-窗口函数有哪些

定义 窗口可以理解为记录集合,窗口函数就是在满足某种条件的记录集合上执行的特殊函数。 即:应用在窗口内的函数。
MySQL查询连续n天登录的用户的方法

MySQL查询连续n天登录的用户的方法

这篇文章介绍了SQL查询至少连续n天登录用户的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
MySql中group_concat字符长度限制1024怎么办

MySql中group_concat字符长度限制1024怎么办

group_concat长度限制默认是1024,如果在实际使用过程中拼接好的字符串长度超过了最大长度,那么最后仅保留前1024个字符,解决group_concat长度限制有两个解决方法
mysql 怎么重启,Windows系统mysql8.0重启的方法详解

mysql 怎么重启,Windows系统mysql8.0重启的方法详解

Windows要重新启动 MySQL,你可以按照以下步骤进行操作,命令提示符界面中,输入以下命令来关闭 MySQL 服务
MySQL8.0的WITH查询实现递归遍历省市区

MySQL8.0的WITH查询实现递归遍历省市区

WITH 子句是 MySQL 中的一种 SQL 结构,又称为 Common Table Expression (CTE)。它在不影响原有 SQL 语句的情况下,允许开发人员临时创建一个内存中的结果集,然后对其进行操作。