jquery 时间相减获取天数_连续登陆最长天数的用户明细

背景:产品做了一个周期7天活动,用户可以每一天解锁一个任务,完成后发放奖励;

需求:用户连续登陆明细数据及连续登陆天数;

目的:用户参与活动的兴趣度;

活动海报图:

6677fbe1999c6bde83adfdd6e1b2135f.png

分析思路:

明细数据:

73bafedc61a45b7bf468d3f5118f91cd.png

-- 根据用户ID分组按日期排序,将日期和分组序号相减得到连续登陆的开始日期,如果开始日期相同说明连续登陆

- 日期减去分区排序的序号,如果新日期相等,则连续登陆  

fb8e2500f9021456a3d85da9d9fde701.png

汇总结果

343c4522801eb556c7f3ca0d34fac7b8.png

附上代码

with, tmp_da_user as (

select

to_date(ds,'yyyymmdd') as ds

,uid

,count(distinct ds) as 完成天数

from tmp_t_user_takse_detail

where status_name = '完成'

and uid in ('203111313364823804','1833903495100023')

group by

ds

,uid

)

, tmp_da_user_diff as (

select

ds

,uid

,完成天数

,dateadd(ds, -ROW_NUMBER() OVER(PARTITION BY uid ORDER BY ds asc ),'dd') AS diff_rn

-- 注意这里是减法;日期减去分区排序的序号,如果新日期相等,则连续登陆

from tmp_da_user

)

select

uid

,min(ds) as start_ds -- 连续登陆的开始时间

,max(ds) as end_ds -- 连续登陆的结束时间

,count(1) as continuous_day -- 连续登陆的天数

,datediff(diff_rn, lag(diff_rn, 1) over(partition by uid order by diff_rn),'dd') interval_day-- 间隔多少天没交易

from tmp_da_user_diff

group by

uid

,diff_rn

补充问题:

如何取用户连续登陆超过3天的明细数据?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值