SQL 求用户的连续登陆天数

这篇博客介绍了一个SQL问题,即如何从用户登录信息表中计算每个用户的连续登录天数。表结构包含user_id和sigin_date字段。解题思路通过创建连续登录标识,然后按此标识和user_id分组,利用count()函数获取连续登录的天数。
摘要由CSDN通过智能技术生成

一、题目描述


求解用户登陆信息表中,每个用户连续登陆平台的天数,连续登陆基础为汇总日期必须登陆,表中每天只有一条用户登陆数据(计算中不涉及天内去重)。

表描述:user_id:用户的id;

              sigin_date:用户的登陆日期。

二、解法分析


注:求解过程有多种方式,下述求解解法为笔者思路,其他解法可在评论区交流。

思路:

        该问题的突破的在于登陆时间,计算得到连续登陆标识,以标识分组为过滤条件,得到连续登陆的天数,最后以user_id分组,以count()函数求和得到每个用户的连续登陆天数。

        连续登陆标识 =(当日登陆日期 - 用户的登陆日期)- 开窗排序的顺序号(倒序)

三、求解过程及结果展示


1.数据准备

-- 1.建表语句
drop table if exists test_sigindate_cnt;
create table test_sigindate_cnt(
    user_id string
    ,sigin_date string 
)
;
 
-- 2.测试数据插入语句
insert overwrite table test_sigindate_cnt 
    
    select 'uid_1' as user_id,'2021-08-03' as sigin_date        
    union all
    select 'uid_1' as user_id,'2021-08-04' as sigin_date 
    union
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值