当前位置: 首页 > news >正文

【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_orderfrom Delivery
) A 
where A.first_order = 1

注意:这里要用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 Deliverywhere(customer_id,order_date)in (select customer_id, min(order_date)from Deliverygroup by customer_id)group by customer_id
) A

1. 错误举例一

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

错误原因:

在这里插入图片描述

2. 错误举例二

在这里插入图片描述

定位问题:

在这里插入图片描述

http://www.lryc.cn/news/319961.html

相关文章:

  • mvcc介绍
  • 强化PaaS平台应用安全:关键策略与措施
  • K8s 集群高可用master节点ETCD挂掉如何恢复?
  • 【Godot 4.2】常见几何图形、网格、刻度线点求取函数及原理总结
  • 如何利用POI导出报表
  • 自动部署SSL证书到阿里云腾讯云CDN
  • 【系统性】 循序渐进学C++
  • rust - 一个日志缓存记录的通用实现
  • elasticsearch(RestHighLevelClient API操作)(黑马)
  • 用尾插的思想实现移除链表中的元素
  • 【Kubernetes】k8s删除master节点后重新加入集群
  • HCIP—OSPF虚链路实验
  • RAxML-NG安装与使用-raxml-ng-v1.2.0(bioinfomatics tools-013)
  • Tomcat内存马
  • pytorch之诗词生成3--utils
  • OpenAI的ChatGPT企业版专注于安全性、可扩展性和定制化。
  • JS06-class对象
  • 深度学习1650ti在win10安装pytorch复盘
  • Node.js与webpack(三)
  • 测试覆盖率那些事
  • Etcd 介绍与使用(入门篇)
  • Docker 安装 LogStash
  • Selenium笔记
  • ChatGPT :确定性AI源自于确定性数据
  • linux驱动开发面试题
  • 【AI】Ubuntu系统深度学习框架的神经网络图绘制
  • AI推介-大语言模型LLMs论文速览(arXiv方向):2024.03.05-2024.03.10—(2)
  • AI解答——DNS、DHCP、SNMP、TFTP、IKE、RIP协议
  • 【TypeScript系列】声明合并
  • zookeeper基础学习之六: zookeeper java客户端curator