MySQL练手 --- 1251. 平均售价

题目链接:1251. 平均售价

思路:

由题意可知,Prices表和UnitsSold表,表的连接关系为一对一,连接字段(匹配字段)为product_id

要求:查找每种产品的平均售价。而Prices表含有价格还有价格的时间限制却没有产品出售的数量,UnitsSold表含有产品出售的日期以及产品出售的数量。

有的产品定了价但没有卖出去,这种也得算出产品的平均售价。(平均售价标记为0)所以使用左连接将Prices表和UnitsSold表连接起来,编写相应的过滤条件即可。

解题过程:

题目要求:查找每种产品的平均售价
Prices表和UnitsSold表进行左连接

SELECT *
FROM prices p
LEFT JOIN unitssold u
ON p.product_id = u.product_id;

在这里插入图片描述
看第一条记录,product_id 为1的产品,定价为5,截止时间从2019-02-172019-02-28,可是产品却在2019-03-01出售过,很明显不符合常理,所以再增加过滤条件u.purchase_date BETWEEN p.start_date AND,变为p.product_id = u.product_id AND u.purchase_date BETWEEN p.start_date AND p.end_date

SELECT *
FROM prices p
LEFT JOIN unitssold u
ON p.product_id = u.product_id AND u.purchase_date BETWEEN p.start_date  AND p.end_date;

在这里插入图片描述
然后就是对其进行分组,计算每种产品的平均售价

按产品 id 进行分组(GROUP BY p.product_id),计算平均售价,SUM(p.price * u.units) / SUM(u.units)

题目要求平均售价的结果 应该 四舍五入到小数点后两位。所以再使用ROUND函数

又因为,有的产品定了价但没有卖出去,这种也得算出产品的平均售价,所以最后使用IFNULL函数对其判断是否为NULL

Code

SELECT p.product_id, IFNULL(ROUND(SUM(p.price * u.units) / SUM(u.units),2),0) average_price 
FROM prices p
LEFT JOIN unitssold u
ON p.product_id = u.product_id AND u.purchase_date BETWEEN p.start_date  AND p.end_date
GROUP BY p.product_id;
  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
mysql-connector-java-8.0.34.jar是一个用于连接Java程序和MySQL数据库的JDBC驱动程序。JDBC是Java数据库连接的标准接口,它允许开发人员使用Java编程语言来访问和操作各种类型的数据库。而mysql-connector-java-8.0.34.jar则是MySQL官方提供的Java驱动程序,它实现了JDBC接口,可以通过JDBC API连接和操作MySQL数据库。 使用mysql-connector-java-8.0.34.jar,开发人员可以在Java程序中直接建立与MySQL数据库的连接,并执行各种数据库操作,例如执行SQL查询、插入、更新和删除数据等。该驱动程序提供了一系列的API,开发人员可以使用这些API来执行数据库操作,如连接数据库、设置查询参数、处理结果集等。 mysql-connector-java-8.0.34.jar具有良好的稳定性和性能,可以与Java程序高效地交互,并提供了大量的功能和选项来满足不同的数据库操作需求。它支持各种版本的MySQL数据库,并兼容最新的JDBC规范。 为了使用mysql-connector-java-8.0.34.jar,开发人员需要将它添加到Java项目的类路径中,并在代码中加载和使用该驱动程序。可以通过配置数据库连接字符串、用户名和密码等信息来建立与MySQL数据库的连接,并通过执行SQL语句实现各种数据库操作。 总之,mysql-connector-java-8.0.34.jar是一个重要的Java驱动程序,它为开发人员提供了访问和操作MySQL数据库的能力,使得Java程序可以与MySQL数据库进行无缝的集成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值