SQL查詢連續(xù)登陸7天以上的用戶的方法實現(xiàn)
查詢7天連續(xù)登陸用戶這個問題很經(jīng)典,解決方法也有很多,這里我講一下筆者的方法,希望對大家有幫助。
具體思路:
1、因為每天用戶登錄次數(shù)可能不止一次,所以需要先將用戶每天的登錄日期去重。
2、再用row_number() over(partition by _ order by _)函數(shù)將用戶id分組,按照登陸時間進(jìn)行排序。
3、計算登錄日期減去第二步驟得到的結(jié)果值,用戶連續(xù)登陸情況下,每次相減的結(jié)果都相同。
4、按照id和日期分組并求和,篩選大于等于7的即為連續(xù)7天登陸的用戶。
表信息如下圖

第一步:用戶登錄日期去重
select DISTINCT date(date) as 日期,id from orde;
結(jié)果為:

第二步:用row_number() over()函數(shù)計數(shù)
select *,row_number() over(PARTITION by id order by 日期) as cum from (select DISTINCT date(date) as 日期,id from orde)a;
結(jié)果為:

第三步:日期減去計數(shù)值得到結(jié)果
select *,date(日期)-cum as 結(jié)果 from (select *,row_number() over(PARTITION by id order by 日期) as cum from (select DISTINCT date(date) as 日期,id from orde)a)b;
結(jié)果:

第四步:根據(jù)id和結(jié)果分組并計算總和,大于等于7的即為連續(xù)登陸7天的用戶
select id,count(*) from (select *,date(日期)-cum as 結(jié)果 from (select *,row_number() over(PARTITION by id order by 日期) as cum from (select DISTINCT date(date) as 日期,id from orde)a)b)c GROUP BY id,結(jié)果 having count(*)>=7;
結(jié)果為:

用了多次嵌套查詢,最終得到我們需要的結(jié)果。
到此這篇關(guān)于SQL查詢連續(xù)登陸7天以上的用戶的方法實現(xiàn)的文章就介紹到這了,更多相關(guān)SQL查詢連續(xù)登陸用戶內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信