共計 1478 個字符,預計需要花費 4 分鐘才能閱讀完成。
丸趣 TV 小編給大家分享一下如何使用 mysql 計算本年用戶最大未登錄時間段,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
計算本年用戶最大未登錄時間段
space_user_task_statistics_log 如果用戶登錄過, 則將信息記入該表
主要信息有用戶 ID 和登錄時間
space_user 記錄用戶基本信息. 主要包括用戶 ID 和注冊時間信息.
需求:
查所有用戶在 2017 年最大的未登錄時間段
如果用戶在 2017 年才注冊, 那么有效時間從注冊時間開始算。
其實這是一個 MySQL 計算連續范圍的問題。
SQL
ol start= 1 >
select userid,startdate,enddate,diff from (
select t3.*,when userid=@gid then @rn:=@rn+1 when @gid:=userid then @rn:=1 end rank
from (
select userid,dt-interval rn min(dt) startdate,max(dt) enddate,
datediff(max(dt),min(dt)) diff
from (
select
cal.dt,cal.userid,when cal.userid=@gid then @rn:=@rn+1 when @gid:=cal.userid then @rn:=1 end rn
from
(
select dt,userid from (
select 2017-01-01 +interval id-1 from nums,(select @gid:=0,@rn:=0) vars where id =dayofyear(now())
) var,
(
select u.userid,u.registertime from space_user u
where exists(select * from space_user_task_statistics_log l where l.createDate = 2017-01-01 and l.userid=u.userid)
) userlist
where dt =date(userlist.registertime)
) cal
join
(
select log.userid,log.createDate from
space_user_task_statistics_log log
where log.loginflag=1 and log.createDate = 2017-01-01
) t1 on(t1.userid=cal.userid and cal.dt=t1.createDate)
where createdate is null
order by userid,dt
) t2
group by userid,dt-interval rn order by userid,diff desc
) t4 where rank=1
order by diff desc;
生產查詢一次耗時 10 分鐘左右.
diff 是最大未登錄時間段的天數.
以上是“如何使用 mysql 計算本年用戶最大未登錄時間段”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注丸趣 TV 行業資訊頻道!