SQL-每日一题【1251. 平均售价】

题目

Table: Prices

Table: UnitsSold

编写SQL查询以查找每种产品的平均售价。
average_price 应该四舍五入到小数点后两位。

查询结果格式如下例所示:

解题思路

1.题目要求查询每种产品的平均售价。给出了两个表,我们用聚合查询来解决此问题。

2.首先我们将两个表做连接,连接条件是 p.product_id = u.product_id,然后我们在筛选出出售日期在保质期内的记录,where u.purchase_date >= p.start_date and u.purchase_date <= p.end_date ,最后我们使用sum()函数计算出平均值,再用round()函数保留两位小数即可。

代码实现

sql 复制代码
select p.product_id, round(sum(p.price * u.units) / sum(u.units), 2) average_price
from Prices p
join UnitsSold u 
on p.product_id = u.product_id
where u.purchase_date >= p.start_date
and u.purchase_date <= p.end_date
group by product_id

测试结果

相关推荐
立志成为大牛的小牛9 分钟前
数据结构——五十六、排序的基本概念(王道408)
开发语言·数据结构·程序人生·算法
宋军涛1 小时前
记一次Sqlserver数据库存储过程调用导致的连接池耗尽事件
数据库
沿着路走到底1 小时前
将数组倒序,不能采用reverse,算法复杂度最低
算法
前端小臻1 小时前
MySQL 错误 1005 (errno: 150) 深度解析与解决方案
数据库·mysql
IDIOT___IDIOT1 小时前
KNN and K-means 监督与非监督学习
学习·算法·kmeans
魔镜前的帅比1 小时前
向量数据库原理
数据库·人工智能
Dev7z1 小时前
在MySQL里创建数据库
android·数据库·mysql
Hcoco_me1 小时前
大模型面试题18:t-SNE算法详解及入门实操
算法
Leon-Ning Liu1 小时前
19C Oracle 集群(RAC)软件 与数据库软件 PSU 补丁部署流程
数据库·oracle