题解 | #国庆期间近7日日均取消订单量#

国庆期间近7日日均取消订单量

http://www.nowcoder.com/practice/2b330aa6cc994ec2a988704a078a0703

此题共包含两张表:

表1:tb_get_car_record

表2:tb_get_car_order

要解决的问题:

请统计国庆头3天里,每天的近7日日均订单完成量和日均订单取消量,按日期升序排序。结果保留2位小数。

解题思路:

  1. 统计订单完成量和订单取消量
  2. 利用窗口函数,统计每天近7日的订单完成量和订单取消量
  3. 计算每天近7日的订单完成量和订单取消量,取时间为国庆头3天
  4. 按日期升序排序,结果取2位小数

知识点:

  1. 窗口函数各个参数的含义:
  • partition by :分组子句,表示分析函数的计算范围,不同的组互不相干;
  • ORDER BY:排序子句,表示分组后,组内的排序方式;
  • ROWS/RANGE:窗口子句,是在分组后,组内的子分组(也称窗口),此时分析函数的计算范围是子分组。
  1. 区分rows和range的区别
  • rows:定义当前行的固定前后记录, 以行号为基准进行计算,计算结果是一个自增长的汇总
  • range:选项包含窗口里的所有行, 以order by为基准进行计算,用可能出现重复值
  1. 注意: 当窗口函数order by 没有显示给出行的作用域范围时,默认为 RANGE between UNBOUNDED PRECEDING AND CURRENT ROW

alt

select dt, 
	   ROUND(finish_num/7,2) finish_num_7d, 
	   ROUND(cancel_num/7,2) cancel_num_7d
from(select dt,
             sum(finish_num)over(order by dt rows 6 preceding) as finish_num,
             sum(cancel_num)over(order by dt rows 6 preceding) as cancel_num
     from(select date(order_time) dt,
                  sum(if (start_time is not null,1,0)) as finish_num,
                  sum(if (start_time is null,1,0)) as cancel_num
          from tb_get_car_order
          group by date(order_time)
          ) t 
			) a 
where dt between '2021-10-01' and '2021-10-03'
全部评论
sum(finish_num)over(order by dt rows 6 preceding) as finish_num, sum(cancel_num)over(order by dt rows 6 preceding) as cancel_num 为啥是6?
1
送花
回复
分享
发布于 2022-03-17 09:25

相关推荐

5 1 评论
分享
牛客网
牛客企业服务