题解 | #某宝店铺连续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

全部评论

相关推荐

10-09 09:39
门头沟学院 C++
HHHHaos:这也太虚了,工资就一半是真的
点赞 评论 收藏
分享
牛客737698141号:他们可以看到在线简历的。。。估计不合适直接就拒了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务