题解|连续天筛选 #连续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