计算即时订单比例-首单使用开窗函数row_number()

1 需求

即时订单和计划订单

订单配送中,如果期望配送日期和下单日期相同,称为即时订单,如果期望配送日期和下单日期不同,称为计划订单。

请从配送信息表(delivery_info)中求出每个用户的首单(用户的第一个订单)中即时订单的比例,保留两位小数,以小数形式显示。

配送信息表 delivery_info

期望结果

2 实现

思路

请从配送信息表(delivery_info)中求出每个用户的首单(用户的第一个订单)中即时订单的比例,保留两位小数,以小数形式显示。

首先需要从数据集中拿出每个用户的首单,一般都是使用排序开窗函数进行操作。然后计算即时订单的比例,只需要从拿出的首单数据中分别计算两个指标,再相除即可,注意需求中需要保留两位小数,所以可以使用 decimal 类型来展示最终的结果。

实现

1 使用开窗函数获取每一个用户的首单数据

复制代码
select * from (
	select user_id,order_date,custom_date,
		row_number() over(partition by user_id order by order_date) rn
	from delivery_info
) t1 where rn=1

2 直接在结果 1 的基础上进行指标的统计和结果的输出即可,需要将结果转换为 decimal(10,2) 展示

复制代码
select 
	cast(round(sum(if(order_date = custom_date, 1, 0)) / count(1), 2) 
         as decimal(10,2)) percentage
from (
	select user_id,order_date,custom_date,
		row_number() over(partition by user_id order by order_date) rn
	from delivery_info
) t1 where rn=1
相关推荐
大数据狂人12 小时前
从 Hive 数仓出发,全面剖析 StarRocks、MySQL、HBase 的使用场景与区别
hive·mysql·hbase
青木川崎1 天前
Hive_sql如何计算连续签到天数
hive·hadoop·sql
Jay Kay1 天前
hive新增列之后插入新数据时,新列为NULL的解决办法
数据仓库·hive·hadoop
Zhang.jialei1 天前
HiveMQ 2024.9 设计与开发文档
hive·物联网·activemq
Java烘焙师2 天前
架构师必备:实时对账与离线对账
hive·mysql·架构·对账
让头发掉下来3 天前
Sqoop详细学习文档
大数据·hive·hadoop·hbase·sqoop
非极限码农4 天前
Hive SQL (HQL) 编辑指南
hive·hadoop·sql
非极限码农4 天前
Hive数仓部署/分层/ETL脚本基础指南
数据仓库·hive·hadoop·etl
大数据狂人6 天前
深入剖析 StarRocks 与 Hive 的区别、使用场景及协同方案实践
大数据·starrocks·hive·数仓
wzy06236 天前
基于 Hadoop 生态圈的数据仓库实践 —— OLAP 与数据可视化(二)
hive·hadoop·impala·sparksql