当前位置:   article > 正文

【SQL】1174. 即时食物配送 II (窗口函数row_number; group by写法;对比;定位错因)

【SQL】1174. 即时食物配送 II (窗口函数row_number; group by写法;对比;定位错因)

前述

推荐学习: 通俗易懂的学会:SQL窗口函数

题目描述

leetcode题目:1174. 即时食物配送 II

在这里插入图片描述
在这里插入图片描述

写法一:窗口函数

分组排序(以customer_id 分组,按照order_date 排序),窗口函数应用。

select round((sum(if(order_date=customer_pref_delivery_date, 1, 0))/count(*))*100, 2) as immediate_percentage 
from (
    select *,
        row_number() over(partition by customer_id order by order_date) as first_order
    from Delivery
) A 
where A.first_order = 1
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

注意:这里要用row_number(), 确保每个用户的首次订单只有一个。

  • 如果用dense_rank()或者是rank():例如,当用户1在同一天下了两个订单时,此时会将这两个订单都统计在内,但实际只需要统计一个即可。

rank()、dense_rank()、row_number() 的区别

在这里插入图片描述
图片引用自 通俗易懂的学会:SQL窗口函数

写法二: group by

正确写法:

-- 方法二:不用窗口函数, 用group by, right!
-- 再用一次 group by customer_id 把同一个用户的两个订单去重
select round((sum(if(order_date=customer_pref_delivery_date, 1, 0))/count(*))*100, 2) as immediate_percentage
from (
    select *
    from Delivery
    where(customer_id,order_date)in (
        select customer_id, min(order_date)
        from Delivery
        group by customer_id
    )
    group by customer_id
) A
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

1. 错误举例一

试图不用窗口函数,直接用group by
下图是错误示例:
在这里插入图片描述

错误原因:

在这里插入图片描述

2. 错误举例二

在这里插入图片描述

定位问题:

在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/263026
推荐阅读
  

闽ICP备14008679号