连续三天访问的用户情况-mysql

– mysql


select author_id,max(daycnt) as days_cnt
    from (
        select author_id,firstdt,count(*) as daycnt
        from (
             select distinct author_id,answer_date  , 
			 date_sub(answer_date, interval dense_rank() over(partition by author_id order by answer_date )-1 day) as firstdt
			 from answer_tb as a 
        )as b
        group by author_id,firstdt
    ) as c 
    group by author_id 

思路:使用dense_rank 窗口函数,根据author_id 进行分组,时间进行排序,
然后用时间-这个递增的数字,如果连续发布则 时间-对应的数字 产生的时间是一样的(连续的第一天)

– sql server

drop table if exists #answer_tb
create table #answer_tb
(
    author_id varchar(200)
    ,answer_date  date, 
)
insert into #answer_tb
select 'a','2022-07-01'
union all 
select 'a','2022-07-02'
union all 
select 'a','2022-07-03'
union all 
select 'b','2022-07-04'
union all 
select 'b','2022-07-05'


select distinct author_id,answer_date,dense_rank() over(partition by author_id order by answer_date ) as firstdtcnt,DATEADD(dd,1,DATEADD(dd,-1*dense_rank() over(partition by author_id order by answer_date ),answer_date)) as firstdt
from #answer_tb as a 
  

在这里插入图片描述

	select author_id,firstdt,count(*) as daycnt
	from (
	        select distinct author_id,answer_date,dense_rank() over(partition by author_id order by answer_date ) as firstdtcnt 
	                        ,DATEADD(dd,1,DATEADD(dd,-1*dense_rank() over(partition by author_id order by answer_date ),answer_date)) as firstdt
	from #answer_tb as a 
	)as b
	group by author_id,firstdt

在这里插入图片描述

# 求解 连续 多少天访问过的用户id,和天数
select author_id,max(daycnt) as days_cnt
from (
    select author_id,firstdt,count(*) as daycnt
    from (
            select distinct author_id,answer_date,dense_rank() over(partition by author_id order by answer_date ) as firstdtcnt 
                            ,DATEADD(dd,1,DATEADD(dd,-1*dense_rank() over(partition by author_id order by answer_date ),answer_date)) as firstdt
			from #answer_tb as a 
    )as b
    group by author_id,firstdt
) as c 
group by author_id 

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值