题解 | #零食类商品中复购率top3高的商品#

零食类商品中复购率top3高的商品

https://www.nowcoder.com/practice/9c175775e7ad4d9da41602d588c5caf3

#1.创建临时表a保存零食类商品id和uid
with a as
(
    select od.product_id product_id, uid
    from tb_product_info pi 
    inner join tb_order_detail od
    on pi.product_id = od.product_id
    inner join tb_order_overall ov
    on ov.order_id = od.order_id
    where event_time BETWEEN 
        date_sub((select max(event_time) from tb_order_overall),INTERVAL 89 day)
        and (select max(event_time) from tb_order_overall)
       and tag = '零食'
       and status = 1
)

#2.计算复购率
select repurchase_table.product_id, 
round(repeated_num / total_num, 3) as repurchase_rate
from
    #repurchase_table保存复购人数
    (
        select product_id, 
        (case when count(uid)>1 
            then count(distinct uid)
            else 0
            end) as repeated_num
        from a
        group by product_id, uid
    ) repurchase_table
right join
    #total_table总人数
    (
    select product_id, count(distinct uid) as total_num
        from a
        group by product_id
    ) total_table
on repurchase_table.product_id = total_table.product_id 
order by repurchase_rate desc, product_id 
limit 3

这题好难啊,写了一上午。。

首先是日期函数:计算日期区间用date_add(日期, interval x day/month..)和between and

接着是复购率计算:对每个product_id都要计算购买人数和复购人数,要分别计算并按照product_id把两个表连接

全部评论

相关推荐

和蔼:在竞争中脱颖而出,厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了
点赞 评论 收藏
分享
FFFcaptain328:入职即送东南亚腰子之旅👿
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务