计算某日新增用户,及其次日、3日、3日内的留存率

计算某日新增用户,及其次日、3日及其3日内的留存率

user_id 用户

dt 时间

login 表名

select 
    login_day,
    count(distinct t.user_id) as uv,
    count(distinct if(datediff(t.dt,s.dt)=1,t.user_id,null))/count(distinct t.user_id) as rt_1,
    count(distinct if(datediff(t.dt,s.dt)=3,t.user_id,null))/count(distinct t.user_id) as rt_3,
    count(distinct if(datediff(t.dt,s.dt)<=3,t.user_id,null))/count(distinct t.user_id) as rt_3_n
from(
    select user_id, min(dt) as login_day
    from login
    group by user_id
) t
left join login s
on t.user_id = s.user_id
group by login_day


计算某日的次日、3日及其3日内的留存率

select 
    dt,
    count(if(datediff(next_dt,dt)=1,user_id,null))/count(user_id) as rt_1,
    count(if(datediff(third_dt,dt)=3,user_id,null))/count(user_id) as rt_3,
    count(if(datediff(th_dt,dt)<=3,user_id,null))/count(user_id) as rt_3_n
from(
    select 
        user_id,
        dt,
        lead(dt,1) over(partition by user_id order by dt) as next_dt,
        lead(dt,3) over(partition by user_id order by dt) as third_dt,
        lead(dt,1) over(partition by user_id order by dt) as th_dt,
    from login
) t
group by dt

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以使用Java的Calendar类和Date类来判断某日是当月第几个工作。具体实现可以参考以下代码: ```java import java.util.Calendar; import java.util.Date; public class Test { public static void main(String[] args) { // 创建期对象 Calendar calendar = Calendar.getInstance(); calendar.set(Calendar.YEAR, 2022); calendar.set(Calendar.MONTH, Calendar.JANUARY); calendar.set(Calendar.DAY_OF_MONTH, 11); Date date = calendar.getTime(); // 计算当月第几个工作 int workDayCount = 0; calendar.set(Calendar.DAY_OF_MONTH, 1); int maxDay = calendar.getActualMaximum(Calendar.DAY_OF_MONTH); for (int i = 1; i <= maxDay; i++) { calendar.set(Calendar.DAY_OF_MONTH, i); int dayOfWeek = calendar.get(Calendar.DAY_OF_WEEK); if (dayOfWeek != Calendar.SATURDAY && dayOfWeek != Calendar.SUNDAY) { workDayCount++; } if (i == calendar.get(Calendar.DAY_OF_MONTH)) { break; } } calendar.setTime(date); int dayOfMonth = calendar.get(Calendar.DAY_OF_MONTH); int dayOfWeek = calendar.get(Calendar.DAY_OF_WEEK); int ordinal = (dayOfMonth - (dayOfWeek - 2) + 7) / 7; if (dayOfWeek != Calendar.SATURDAY && dayOfWeek != Calendar.SUNDAY) { workDayCount--; } System.out.println("The " + ordinal + "th workday of the month."); } } ``` 以上代码中,我们首先创建一个期对象,并设置为需要计算期。然后,我们使用`calendar.set(Calendar.DAY_OF_MONTH, 1)`方法将期设置为当月的1号,通过`calendar.getActualMaximum(Calendar.DAY_OF_MONTH)`方法获取当月的总天数。接下来,我们遍历当月的所有期,判断是否为工作,如果是则将工作计数器加1。然后,我们通过`calendar.setTime(date)`方法将期设置为需要计算期,通过`(dayOfMonth - (dayOfWeek - 2) + 7) / 7`计算出当天是当月第几个星期几,最后判断当天是否为工作,如果是则将工作计数器减1,最终输出当天是当月第几个工作。 需要注意的是,以上代码中计算当月第几个工作的方法是按照中国的法定工作(周一至周五)来计算的,如果需要按照其他国家或地区的法定工作计算,则需要相应地修改代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值