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

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

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

select
     user_id,
     count(*) as days_count     
from (select  
    sales_date,user_id ,
    row_number() over(partition by user_id order by sales_date) as rk
from sales_tb) t group by  user_id,date_sub(sales_date,interval rk day) 
        HAVING COUNT(*) >= 2;

首先分区内排序 得到每个user_id的sales_date排名

date_sub表示销售日期减去排名 --> 这样连续的sales_date会得到1个相同的日期 即min(sales_date)-1 ;

-----------------------------------------------------------------------------------------------------

user_id sales_date rk sub(sales_date,interval rk day)

------------------------------------------------------------------------------------------------------

1 2021-01-05 1 2021-01-04

1 2021-01-06 2 2021-01-04

1 2021-01-06 3 2021-01-03

2 2021-01-05 1 2021-01-04

2 2021-01-07 2 2021-01-05

--------------------------------------------------------------------------------------------------------

根据user_id和min(sales_date)-1进行group by分组 得到每个user_id和min(sales-date)-1的count(*)

譬如上面这个例子,user_id和sub(sales_date,interval rk day)得到的分组如下:

------------------------------------------------------------------------------------------------------

user_id sub(sales_date,interval rk day) count(*)

------------------------------------------------------------------------------------------------------

1 2021-01-04 2

1 2021-01-03 1

2 2021-01-04 1

2 2021-01-05 1

------------------------------------------------------------------------------------------------------

题目要求连续天数是多少让having count(*) > 多少;

全部评论

相关推荐

叶扰云倾:进度更新,现在阿里云面完3面了,感觉3面答得还行,基本都答上了,自己熟悉的地方也说的比较细致,但感觉面试官有点心不在焉不知道是不是不想要我了,求阿里收留,我直接秒到岗当阿里孝子,学校那边的房子都退租了,下学期都不回学校,全职猛猛实习半年。这种条件还不诱人吗难道 然后现在约到了字节的一面和淘天的复活赛,外加猿辅导。华为笔试完没动静。 美团那边之前投了个base广州的,把我流程卡麻了,应该是不怎么招人,我直接简历挂了,现在进了一个正常的后端流程,还在筛选,不知道还有没有hc。
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-24 14:18
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务