select uid,count(submit_time) as exam_complete_cnt
from (
    select uid,start_time,submit_time,
    dense_rank() over(partition by uid order by date_format(start_time,'%Y%m') desc) as recent_month 
	# 使用连续排名将每个月分组,按照时间倒序排序,并用顺序数字标记
    from exam_record
) t1
where recent_month<=3
# 获取顺序倒数第3以内的三组
group by uid
having count(start_time) = count(submit_time)
# 开始和结束的数量相同,即当前UID分组,在已知的三个月内试卷都是已完成的。
order by exam_complete_cnt desc,uid desc