亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL怎么查詢連續登錄的用戶情況

發布時間:2021-12-31 14:10:47 來源:億速云 閱讀:331 作者:小新 欄目:開發技術

這篇文章主要為大家展示了“SQL怎么查詢連續登錄的用戶情況”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“SQL怎么查詢連續登錄的用戶情況”這篇文章吧。

以連續3天為例,使用工具:MySQL

1.創建SQL表:

create table if not exists orde(id varchar(10),date datetime,orders varchar(10));
insert into orde values('1' , '2019/1/1',10 );
insert into orde values('1' , '2019/1/2',109 );
insert into orde values('1' , '2019/1/3',150 );
insert into orde values('1' , '2019/1/4',99);
insert into orde values('1' , '2019/1/5',145);
insert into orde values('1' , '2019/1/6',1455);
insert into orde values('1' , '2019/1/7',199);
insert into orde values('1' , '2019/1/8',188 );
insert into orde values('4' , '2019/1/1',10 );
insert into orde values('2' , '2019/1/2',109 );
insert into orde values('3' , '2019/1/3',150 );
insert into orde values('4' , '2019/1/4',99);
insert into orde values('5' , '2019/1/5',145);
insert into orde values('6' , '2019/1/6',1455);
insert into orde values('7' , '2019/1/7',199);
insert into orde values('8' , '2019/1/8',188 );
insert into orde values('9' , '2019/1/1',10 );
insert into orde values('9' , '2019/1/2',109 );
insert into orde values('9' , '2019/1/3',150 );
insert into orde values('9' , '2019/1/4',99);
insert into orde values('9' , '2019/1/6',145);
insert into orde values('9' , '2019/1/9',1455);
insert into orde values('9' , '2019/1/10',199);
insert into orde values('9' , '2019/1/13',188 );

查看數據表:

SQL怎么查詢連續登錄的用戶情況

2.使用row_number() over()  排序函數計算每個id的排名,SQL如下:

select *,row_number() over(partition by id order by date ) 'rank'
from orde
where orders is not NULL;

查看數據表:

SQL怎么查詢連續登錄的用戶情況

 3.將date日期字段減去rank排名字段,SQL如下:

select *,DATE_SUB(a.date,interval a.rank day) 'date_sub'
from(
select *,row_number() over(partition by id order by date ) 'rank'
from orde
where orders is not NULL
) a;

查看數據:

 SQL怎么查詢連續登錄的用戶情況

4.根據id和date分組并計算分組后的數量(count)、計算最早登錄和最晚登錄的時間,SQL如下:

select b.id,min(date) 'start_time',max(date) 'end_time',count(*) 'date_count'
from(
select *,DATE_SUB(a.date,interval a.rank day) 'date_sub'
from(
select *,row_number() over(partition by id order by date ) 'rank'
from orde
where orders is not NULL
) a
) b
group by b.date_sub,id
having count(*) >= 3
;

 查看數據:

SQL怎么查詢連續登錄的用戶情況

以上是“SQL怎么查詢連續登錄的用戶情況”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

sql
AI

方正县| 泾阳县| 临朐县| 竹北市| 桓仁| 汕头市| 华安县| 图木舒克市| 苗栗市| 盐津县| 常熟市| 武定县| 潜山县| 南溪县| 东至县| 石棉县| 台东市| 佳木斯市| 渝中区| 额敏县| 固安县| 阿鲁科尔沁旗| 奉节县| 琼海市| 郸城县| 兰考县| 庆安县| 寿阳县| 深水埗区| 宁城县| 米泉市| 宜良县| 新乡市| 绥滨县| 永寿县| 淮滨县| 都昌县| 彭阳县| 德州市| 东乡族自治县| 思茅市|