久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

如何使用mysql計算本年用戶最大未登錄時間段

134次閱讀
沒有評論

共計 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 行業資訊頻道!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-27發表,共計1478字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 桐梓县| 闽清县| 福海县| 原平市| 乐安县| 个旧市| 北碚区| 博野县| 多伦县| 罗甸县| 钦州市| 蚌埠市| 辽中县| 华安县| 图木舒克市| 灵台县| 邵阳县| 苏尼特右旗| 安多县| 青阳县| 宾川县| 江源县| 会昌县| 大英县| 景洪市| 隆子县| 德格县| 和硕县| 曲周县| 霍林郭勒市| 嫩江县| 浦城县| 当涂县| 廊坊市| 卓资县| 邮箱| 清涧县| 韶山市| 慈利县| 平湖市| 凌海市|