码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • SQL练习题:连续登录5天的活跃用户


    题目

    写一个 SQL 查询, 找到活跃用户的 id 和 name.
    活跃用户是指那些至少连续 5 天登录账户的用户.
    返回的结果表按照 id 排序.

    Accounts 表:
    id 是该表主键.
    该表包含账户 id 和账户的用户名.

    idname
    1Winston
    7Jonathan

    Logins 表:
    该表无主键, 可能包含重复项.
    该表包含登录用户的账户 id 和登录日期. 用户也许一天内登录多次.

    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 是活跃用户.


    解法一 窗口函数lead +datediff

    1)去重
    因为登录表汇总了多个日期和id 号,同一天可能回登录多次,我们只需要一个登录日期。所以需要先group by id, login_date去重。
    2)datediff +lead
    再用lead(login_date,4)over()窗口函数查找往下第4个登录日期是否与当前日期相差4天,即连续5天。

    select distinct t.id,a.name
    from (
        select
        	id, 
        	login_date,
        	datediff(
            	lead(login_date, 4) over(partition by id order by login_date)
            	,login_date
            	) as diff   
        from logins
        group by id, login_date
        ) as t
    left join accounts a using(id)
    where t. diff = 4
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    解法二:自连接

    logins自连接后,限制条件有:
    1) id 相同;
    2)日期相差0-4天。
    最后找出符合条件的日期合计达到5个的id。

    如下表所示,如果有连续登录5天,那么在diff列在0-4范围内的会有5行。
    连续登录5天的情况:

    datedate2diff
    tt0
    tt-11
    tt-22
    tt-33
    tt-44

    第二天没有登录的情况:

    datedate2diff
    tt0
    tt-11
    tt-33
    tt-44
    select distinct a.id,a.name
    from (
            select a.id, a.login_date as ad, b.login_date as bd
            from logins a
            join logins b
            	on a.id = b.id and datediff(a.login_date,b.login_date) between 0 and 4
            group by a.id, a.login_date
            having count(distinct b.login_date) = 5) as t 
    left join accounts a on a.id = t.id
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/active-users

  • 相关阅读:
    读书笔记之C Primer Plus 4
    解决问题:已通过系统pip安装了相应模块,但是PyCharm中却提示 No module named xxxx
    DW大学生网页作业制作设计 基于html+css我的家乡贵州网页项目的设计与实现
    JS逆向爬虫---请求参数加密②【某麦数据analysis参数加密】
    面霸的自我修养:synchronized专题
    PolarDB-X 的 in 常量查询
    二十九、【进阶】MySQL索引的概述和索引查询
    Nexus数据备份&恢复
    【是C++,不是C艹】 类与对象 | 认识面向对象 | 访问限定符 | 封装 | this指针
    「Verilog学习笔记」边沿检测
  • 原文地址:https://blog.csdn.net/WHYbeHERE/article/details/125522949
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号