此题共包含两张表:
表1:tb_get_car_record
表2:tb_get_car_order
要解决的问题:
请统计国庆头3天里,每天的近7日日均订单完成量和日均订单取消量,按日期升序排序。结果保留2位小数。
解题思路:
- 统计订单完成量和订单取消量
- 利用窗口函数,统计每天近7日的订单完成量和订单取消量
- 计算每天近7日的订单完成量和订单取消量,取时间为国庆头3天
- 按日期升序排序,结果取2位小数
知识点:
- 窗口函数各个参数的含义:
- partition by :分组子句,表示分析函数的计算范围,不同的组互不相干;
- ORDER BY:排序子句,表示分组后,组内的排序方式;
- ROWS/RANGE:窗口子句,是在分组后,组内的子分组(也称窗口),此时分析函数的计算范围是子分组。
- 区分rows和range的区别
- rows:定义当前行的固定前后记录, 以行号为基准进行计算,计算结果是一个自增长的汇总
- range:选项包含窗口里的所有行, 以order by为基准进行计算,用可能出现重复值
- 注意: 当窗口函数order by 没有显示给出行的作用域范围时,默认为 RANGE between UNBOUNDED PRECEDING AND CURRENT ROW
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'