SQL查詢連續(xù)登陸7天以上的用戶的方法實現(xiàn)
查詢7天連續(xù)登陸用戶這個問題很經(jīng)典,解決方法也有很多,這里我講一下筆者的方法,希望對大家有幫助。
具體思路:
1、因為每天用戶登錄次數(shù)可能不止一次,所以需要先將用戶每天的登錄日期去重。
2、再用row_number() over(partition by _ order by _)函數(shù)將用戶id分組,按照登陸時間進行排序。
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)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SQL Server2022安裝教程的實現(xiàn)步驟(圖文教程)
在日常的工作中,sql server作為一款常用的數(shù)據(jù)庫管理系統(tǒng),安裝與配置就顯得非常重要,本文主要介紹了SQL Server2022安裝教程的實現(xiàn)步驟,感興趣的可以了解一下2023-09-09
sqlserver數(shù)據(jù)庫服務(wù)器讀寫性能之陣列RAID對比簡介
這篇文章主要考慮sqlserver數(shù)據(jù)庫服務(wù)器的讀寫性能優(yōu)化之陣列raid的對比分析,需要的朋友可以參考下2024-04-04
獲取數(shù)據(jù)庫中兩個時間字段的相差天數(shù)及ABS/DATEDIFF函數(shù)應(yīng)用
本文將詳細介紹獲取數(shù)據(jù)庫中兩個時間字段的相差天數(shù)及ABS/DATEDIFF函數(shù)應(yīng)用感興趣的朋友可以了解下哦,希望本文對你鞏固ABS/DATEDIFF函數(shù)有所幫助2013-01-01
SQL Server修改標(biāo)識列方法 如自增列的批量化修改
最近在運行系統(tǒng)時需要對所有服務(wù)器上數(shù)據(jù)結(jié)構(gòu)進行批量修改某個字段的自增屬性改成非自增2012-05-05

