题解 | #某宝店铺连续2天及以上购物的用户及其对应的天数#
某宝店铺连续2天及以上购物的用户及其对应的天数
https://www.nowcoder.com/practice/63ac3be0e4b44cce8dd2619d2236c3bf
#这个题连续日期分组的题,很常见,处理方法都类似,都做到这里了我想很多人应该都会了,开窗就可以解决(评论区有另一种方法开窗,也挺好,我记得以前也听老师讲过,就是先开窗排个序,然后各记录用日期减去刚才排序的各自序号,得到一个日期结果,同一个窗口的记录会得到相同日期结果)。
我这个解对“对应的天数的理解”是各用户对应的各连续2天区域的天数,而不是各个用户的所有天数。
其中“及其对应的次数”说实话我一直不明白是什么意思,而这段代码能通过就说明可能就是我上面描述的那样。
select c.user_id,count(1) as days_count from ( select b.user_id, sum(b.flag) over(partition by b.user_id order by b.sales_date) as groupId from ( select a.user_id, a.sales_date, case when a.sales_date = lag(a.sales_date,1) over(partition by a.user_id order by a.sales_date) then 0 when date_sub(a.sales_date,interval 1 day) = lag(a.sales_date,1) over(partition by a.user_id order by a.sales_date) then 0 else 1 end as flag from (select distinct user_id,sales_date from sales_tb) a ) b )c group by c.user_id,c.groupId having count(1) >= 2
2023/06/22 写的代码。一个用户在期间不同时间段大于两天这里是直接进行了输出。
select user_id,count(1) as days_count from ( select user_id,sales_date, date_sub(sales_date,interval row_number() over(partition by user_id order by sales_date) day) as groupId from ( select sales_date,user_id from sales_tb a group by sales_date,user_id ) t1 ) t2 group by user_id,groupId having count(1) > 1 order by user_id