题目:有一张用户签到表t_user_attendence
,标记每天用户是否签到(说明:该表包含所有用户所有工作日的出勤记录),表结构为:
fdate --- 日期
fuser_id --- 用户id
fis_sign_in --- 用户是否签到(0/1)
请计算截至当前每个用户已经连续签到的天数
先找用户最近一次未签到日期,再用今天减那个日期
select
fuser_id,
datediff(from_unixtime(unix_timestamp(),'yyyy-MM-dd'),fdate_max) as fconsecutive_days
from
(
select
fuser_id,
max(fdate) fdate_max
from
t_user_attendence
where
fis_sign_in = 0
group by
fuser_id
) t1
;
请计算每个用户历史以来最大的连续签到天数
把用户所有签到记录转化成一条0-1字符串序列,用0做split切割,计算切出来的1序列组中的最大长度
select
fuser_id,
max(length(cut_fsign_record)) as fmax_days
from
(select
fuser_id,
fsign_record,
cut_fsign_record
from
(
select
fuser_id,
concat_ws('0',collect_set(fis_sign_in)) fsign_record
from
t_user_attendence
group by
fuser_id
) t1
lateral view explode(split(fsign_record,'0')) t as cut_fsign_record
) t2
where
cut_fsign_record <> ''
group by
fuser_id
;