## 连续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