当前位置: 首页 > article >正文

经典sql题(二)求连续登录最多天数用户

示例数据

假设我们的 test 表有以下数据:

iddate
12023-10-01 08:00:00
12023-10-02 09:00:00
12023-10-03 10:00:00
12023-10-05 11:00:00
22023-10-01 10:00:00
22023-10-02 12:00:00
22023-10-03 14:00:00
22023-10-04 15:00:00
32023-10-01 16:00:00
32023-10-02 16:00:00
32023-10-03 16:00:00
32023-10-04 16:00:00
第一步:去重并提取日期
SELECT 
    id,
    SUBSTR(date, 1, 10) AS date1
FROM 
    test
GROUP BY 
    id, SUBSTR(date, 1, 10);

结果(表 table1):

iddate1
12023-10-01
12023-10-02
12023-10-03
12023-10-05
22023-10-01
22023-10-02
22023-10-03
22023-10-04
32023-10-01
32023-10-02
32023-10-03
32023-10-04
第二步:为每个用户和日期生成序列号
SELECT 
    id,
    date1,
    DATE_SUB(date1, INTERVAL ROW_NUMBER() OVER (PARTITION BY id ORDER BY date1) DAY) AS date2
FROM (
    SELECT 
        id,
        SUBSTR(date, 1, 10) AS date1
    FROM 
        test
    GROUP BY 
        id, SUBSTR(date, 1, 10)
) AS table1;  -- 使用 'table1' 作为别名

结果(表 table2):

iddate1date2
12023-10-012023-10-01
12023-10-022023-10-01
12023-10-032023-10-01
12023-10-052023-10-04
22023-10-012023-10-01
22023-10-022023-10-01
22023-10-032023-10-01
22023-10-042023-10-01
32023-10-012023-10-01
32023-10-022023-10-01
32023-10-032023-10-01
32023-10-042023-10-01
第三步:统计每个用户的最大连续登录天数
SELECT 
    id, 
    MAX(day_cnt) AS max_day_cnt
FROM (
    SELECT 
        id,
        date2,
        COUNT(*) AS day_cnt
    FROM (
        SELECT 
            id,
            date1,
            DATE_SUB(date1, INTERVAL ROW_NUMBER() OVER (PARTITION BY id ORDER BY date1) DAY) AS date2
        FROM (
            SELECT 
                id,
                SUBSTR(date, 1, 10) AS date1
            FROM 
                test
            GROUP BY 
                id, SUBSTR(date, 1, 10)
        ) AS table1
    ) AS table2
    GROUP BY 
        id, date2
) AS final_table
GROUP BY id
ORDER BY max_day_cnt DESC
LIMIT 1;

结果(如果求的是用户天数而非用户则无需ORDER BY):

idmax_day_cnt
34

完整步骤解析

  1. 去重提取日期

    • 查询:提取每个用户的唯一登录日期。
    • 结果表 table1:显示每个用户的唯一日期。
  2. 为每个用户生成序列号

    • 查询:为每个用户的日期生成序号,并计算 date2
    • 结果表 table2:显示用户的日期和对应的 date2
  3. 统计用户最大连续登录天数

    • 查询:根据 date2 统计每个用户的连续登录天数,并通过 MAX() 函数获取每个用户的最大连续登录天数。
    • 最终结果:显示连续登录天数最多的用户及其天数。

http://www.kler.cn/news/313737.html

相关文章:

  • 将编程融入日常生活:编程游戏化学习
  • 内网穿透软件有哪些?
  • 搜维尔科技:工程师已经解决OptiTrack捕捉过程中肘部不自然的弯曲
  • 十五,Spring Boot 整合连接数据库(详细配置)
  • 金仓数据库 KingbaseES参考手册-(8.函数(三))
  • 在HTML中添加图片
  • Oracle 数据库常用命令与操作指南
  • 安全装备检测系统源码分享
  • 【Python报错已解决】To update, run: python.exe -m pip install --upgrade pip
  • sqlgun靶场通关攻略
  • 代码随想录算法训练营day39
  • 【C/C++语言系列】浅拷贝和深拷贝
  • php curl发送get、post请求
  • 等保测评:企业如何建立安全的开发环境
  • Opencv + Opencv_contrib的源码编译安装以及C++调用和cmakelist编写
  • 8.安卓逆向-安卓开发基础-安卓四大组件1
  • DataGrip在Windows和MacOS平台上的快捷键
  • 如何导入数据库时将ID也导入进去
  • 【推广】图书|2024新书《大模型RAG实战:RAG原理、应用与系统构建》汪鹏、谷清水、卞龙鹏等,机械工业出版社
  • 地平线占用预测 FlashOcc 参考算法-V1.0
  • 彩漩科技亮相企业出海峰会,展示智能办公新力量
  • 图解Redis 01 | 初识Redis
  • 网络爬虫Request静态页面数据获取
  • 有关shell指令练习2
  • Redis的持久化和高可用性
  • 深入探究HTTP网络协议栈:互联网通信的基石
  • es的封装
  • 如何为公司注册域名邮箱?
  • JVM四种垃圾回收算法以及G1垃圾回收器(面试)
  • 2024年9月python二级基本编程题和简单应用题解析(一)