LeetCode 1251. 平均售价

题目链接:1251. 平均售价

题目描述

表:Prices

Column Name Type
product_id int
start_date date
end_date date
price int

(product_id,start_date,end_date) 是 prices 表的主键(具有唯一值的列的组合)。
prices表的每一行表示的是某个产品在一段时期内的价格。 每个产品的对应时间段是不会重叠的,这也意味着同一个产品的价格时段不会出现交叉。

表:UnitsSold

Column Name Type
product_id int
purchase_date date
units int

该表可能包含重复数据。

该表的每一行表示的是每种产品的出售日期,单位和产品 id。

编写解决方案以查找每种产品的平均售价。average_price 应该四舍五入到小数点后两位 ,返回结果表无顺序要求

结果格式如下例所示。

输入:

Prices table:

product_id start_date end_date price
1 2019-02-17 2019-02-28 5
1 2019-03-01 2019-03-22 20
2 2019-02-01 2019-02-20 15
2 2019-02-21 2019-03-31 30

UnitsSold table:

product_id purchase_date units
1 2019-02-25 100
1 2019-03-01 15
2 2019-02-10 200
2 2019-03-22 30

输出:

product_id average_price
1 6.96
2 16.96

解释:

平均售价 = 产品总价 / 销售的产品数量。

产品 1 的平均售价 = ((100 * 5)+(15 * 20) )/ 115 = 6.96

产品 2 的平均售价 = ((200 * 15)+(30 * 30) )/ 230 = 16.96

题目分析

扫一眼左连接,时间范围匹配,分组求值,保留两位。OK,开始问神奇的海螺:

替换题目中的各值:

sql 复制代码
SELECT u.product_id, units * price as totalprice, u.units
FROM UnitsSold u
         LEFT JOIN Prices p
                   ON (u.purchase_date BETWEEN p.start_date AND p.end_date) AND u.product_id = p.product_id 

效果非常好!

接下来分组、计算均价、保留两位:

sql 复制代码
SELECT p.product_id, ROUND(sum(units * price) / sum(units), 2) as average_price
FROM Prices p
         LEFT JOIN UnitsSold u
                   ON (u.purchase_date BETWEEN p.start_date AND p.end_date) AND u.product_id = p.product_id
group by p.product_id

运行!

好好好,再套一个非空,下班。

代码

sql 复制代码
SELECT p.product_id, COALESCE(ROUND(sum(units * price) / sum(units), 2), 0) as average_price
FROM Prices p
         LEFT JOIN UnitsSold u
                   ON (u.purchase_date BETWEEN p.start_date AND p.end_date) AND u.product_id = p.product_id
group by p.product_id

好,又一段人下人代码,海螺全责🐚

相关推荐
再卷也是菜19 分钟前
C++篇(21)图
数据结构·c++·算法
星轨初途24 分钟前
C++入门(算法竞赛类)
c++·经验分享·笔记·算法
j***827025 分钟前
Mybatis控制台打印SQL执行信息(执行方法、执行SQL、执行时间)
数据库·sql·mybatis
8***f39532 分钟前
SQL中的REGEXP正则表达式使用指南
数据库·sql·正则表达式
M***Z21038 分钟前
【SQL技术】不同数据库引擎 SQL 优化方案剖析
数据库·sql
5***r9351 小时前
SQL实现md5加密方法
数据库·sql
i***77801 小时前
mysql 迁移达梦数据库出现的 sql 语法问题 以及迁移方案
数据库·sql·mysql
t***82111 小时前
【Oracle11g SQL详解】日期和时间函数:SYSDATE、TO_DATE、TO_CHAR 等
数据库·sql
Fantasy丶夜雨笙歌1 小时前
SQL综合实战:从基础约束到高级应用的完整指南
数据库·sql
灰灰勇闯IT1 小时前
KMP算法在鸿蒙系统中的应用:从字符串匹配到高效系统级开发(附实战代码)
算法·华为·harmonyos