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