题解|连续天筛选 #连续2天及以上购物的用户及对应天数#

某宝店铺连续2天及以上购物的用户及其对应的天数

https://www.nowcoder.com/practice/63ac3be0e4b44cce8dd2619d2236c3bf

## 连续2天可以做出来,但是连续2天及以上该怎么写呢?还要统计连续的天数
## 巧思:对同一个用户的不同日期进行排序,如果日期差值 = 排序差值,意味着是连续的天数
# SELECT user_id,sales_date,DENSE_RANK() OVER(PARTITION BY user_id ORDER BY sales_date) AS rk
# FROM sale_tb

SELECT user_id,COUNT(*) AS days_count
FROM (
    SELECT user_id,sales_date,ROW_NUMBER() OVER(PARTITION BY user_id ORDER BY sales_date) AS rk
    FROM sales_tb
    )t1
GROUP BY user_id,DATE_ADD(sales_date,INTERVAL -rk day)
HAVING COUNT(*) >= 2

作差的原理如下:  当时间连续的时候,那么时间减去排序就会得到一个相同的值,同样,作差值相同就说明那段时间连续

B.如何把连续的时间抽出来

group by date_add(sales_date,INTERVAL,-rn day)

group by 作差的结果就是把作差相同的值抽出来进行分组,即把连续的时间抽出分组在一起

C.如何限制连续的时间是多久

这里是连续2天及以上

having count(*)>=2

全部评论

相关推荐

不愿透露姓名的神秘牛友
11-27 10:28
点赞 评论 收藏
分享
牛客771574427号:恭喜你,华杰
点赞 评论 收藏
分享
美团 后端开发 总包n(15%是股票)
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务