with cte_get_timewindow as (
select uid,
datediff(max(start_time),min(start_time))+1 as timediff,# 最长作答相隔天数
max(datediff(nextday,start_time))+1 as days_window, # 连续作答的相隔天数,即'时间窗'
count(start_time) as count_exam # 作答总数量
from (
select uid,exam_id,start_time,
lead(start_time) over(partition by uid order by start_time) as nextday
# 子查询中使用lead函数获取当前行下一行数据进行拼接,获取时间窗
from exam_record
where year(start_time) = 2021
) as t1
group by uid
)
select uid,days_window,
round(count_exam/timediff*days_window,2) as avg_exam_cnt
# 根据最长作答时间差做卷数量规律计算在时间窗内做卷数量
from cte_get_timewindow
where timediff>1
order by days_window desc,avg_exam_cnt desc