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

测试结果

相关推荐
星栈10 小时前
CQRS 双库架构:给事件存储单独开一个数据库,到底值不值?
数据库·全栈
WBluuue10 小时前
Codeforces 1095 Div2(ABCDE)
c++·算法
YF021110 小时前
深度解构Android OkDownload断点续传
android·数据库·okhttp
测试员周周10 小时前
【Appium 系列】第04节-Page Object 模式 — BasePage 基类设计
开发语言·数据库·人工智能·python·语言模型·appium·web app
IT当时语_青山师__JAVA技术栈10 小时前
数组与链表深度解析:从内存布局到工业级实践
java·算法·面试
海棠Flower未眠10 小时前
Spring Boot 2.4后,特定配置文件不能再使用spring.profiles.include的解决思路
数据库·spring boot·spring
吃着火锅x唱着歌10 小时前
LeetCode 496.下一个更大元素I
算法·leetcode·职场和发展
jran-11 小时前
MySQL单表操作
数据库·mysql
不知名的忻11 小时前
关键路径(Java)
java·数据结构·算法·关键路径
大大杰哥11 小时前
2025ccpc南昌补题笔记(前六题)
c++·笔记·算法