https://www.cnblogs.com/ikww/p/12012831.html
table (id,date)
select id,count(*)
from
(select *,date_add(dated,-rown) as startdate
from
(select *,row_number() over(PARTITION by id order by dated) as rown
from
(select distinct id, to_date(date) as dated
from table ) a
) b
)c
GROUP BY id,startdate
having count(*)>=7;
查询7天连续登陆用户这个问题很经典,解决方法也有很多,这里我讲一下笔者的方法,希望对大家有帮助。
具体思路:
1、因为每天用户登录次数可能不止一次,所以需要先将用户每天的登录日期去重。
2、再用row_number() over(partition by _ order by _)函数将用户id分组,按照登陆时间进行排序。
3、计算登录日期减去第二步骤得到的结果值,用户连续登陆情况下,每次相减的结果都相同。
4、按照id和日期分组并求和,筛选大于等于7的即为连续7天登陆的用户。
表信息如下图
第一步:用户登录日期去重
1 |
|
结果为:
第二步:用row_number() over()函数计数
1 |
|
结果为:
第三步:日期减去计数值得到结果
1 |
|
结果:
第四步:根据id和结果分组并计算总和,大于等于7的即为连续登陆7天的用户
1 |
|
结果为:
用了多次嵌套查询,最终得到我们需要的结果。