[SQL智慧航行者] - 连续登录

话不多说, 先看数据表信息.

数据表信息:

数据表如图:

有用户表行为记录表t_act_records表,包含两个字段:uid(用户ID),imp_date(日期)

话不多说, 再看需求~

需求:

编写一个 sql 查询,计算2021年每个月,每个用户连续登录的最多天数?

sql 复制代码
select 
    uid, 
    date_format(imp_date, '%y-%m') as month,
    max(consecutive_days) as max_consecutive_days
from (
    select 
        uid,
        imp_date,
        row_number() over (partition by uid, date_format(imp_date, '%y-%m') order by imp_date) -
        row_number() over (partition by uid, date_format(imp_date, '%y-%m') order by imp_date) as consecutive_days
    from t_act_records
    where year(imp_date) = 2021
) as subquery
group by uid, month;

编写一个 sql 查询,计算2021年每个月,连续2天都有登录的用户名单?

sql 复制代码
select distinct uid, date_format(imp_date, '%y-%m') as month
from t_act_records
where year(imp_date) = 2021
group by uid, date_format(imp_date, '%y-%m')
having count(distinct imp_date) >= 2;

编写一个 sql 查询,计算2021年每个月,连续5天都有登录的用户数?

sql 复制代码
select
    date_format(imp_date, '%y-%m') as month,
    count(distinct uid) as user_count
from (
    select
        uid,
        imp_date,
        row_number() over (partition by uid, date_format(imp_date, '%y-%m') order by imp_date) -
        row_number() over (partition by uid, date_format(imp_date, '%y-%m') order by imp_date) as consecutive_days
    from t_act_records
    where year(imp_date) = 2021
) as subquery
where consecutive_days <= 5
group by month;

最后给大家介绍一下我这边的创建数据表和插入数据的操作步骤, 想要自己测试的话, 可以参考:

sql 复制代码
DROP TABLE if EXISTS t_act_records;
CREATE TABLE t_act_records
(uid  VARCHAR(20),
imp_date DATE);

INSERT INTO t_act_records VALUES('u1001', 20210101);
INSERT INTO t_act_records VALUES('u1002', 20210101);
INSERT INTO t_act_records VALUES('u1003', 20210101);
INSERT INTO t_act_records VALUES('u1003', 20210102);
INSERT INTO t_act_records VALUES('u1004', 20210101);
INSERT INTO t_act_records VALUES('u1004', 20210102);
INSERT INTO t_act_records VALUES('u1004', 20210103);
INSERT INTO t_act_records VALUES('u1004', 20210104);
INSERT INTO t_act_records VALUES('u1004', 20210105);
相关推荐
wefg110 小时前
【MySQL】索引(索引底层原理/创建/查看/删除主键、普通、联合、前缀、全文索引)
数据库·mysql
风向决定发型丶15 小时前
redis集群搭建
数据库·redis·缓存
wei_shuo17 小时前
KES 扩展与插件开发实战:自定义函数、触发器与第三方插件集成
数据库·kes
风中芦苇啊18 小时前
从直接生成到受控配置:新一代图表Agent的SQL安全生成范式
数据库·sql·安全
吴声子夜歌18 小时前
SQL进阶——窗口函数
数据库·sql
周杰伦的稻香18 小时前
MySQL8.0+中引入的SET_USER_ID权限迭代SUPER权限指定 DEFINER
数据库·mysql
动恰客流统计18 小时前
客流统计如何结合AI分析?从传统计数到智能决策的技术升级路径
数据库·人工智能·边缘计算
夏玉林的学习之路18 小时前
如何远程连接服务器
运维·服务器
宠友信息19 小时前
多端数据互通场景下Spring Boot仿小红书源码结构设计
数据库·spring boot·redis·缓存·架构