【力扣】——1521.平均售价

 表:Prices

+---------------+---------+
| Column Name   | Type    |
+---------------+---------+
| product_id    | int     |
| start_date    | date    |
| end_date      | date    |
| price         | int     |
+---------------+---------+
(product_id,start_date,end_date) 是 Prices 表的主键。
Prices 表的每一行表示的是某个产品在一段时期内的价格。
每个产品的对应时间段是不会重叠的,这也意味着同一个产品的价格时段不会出现交叉。
 

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/average-selling-price
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

表:UnitsSold

+---------------+---------+
| Column Name   | Type    |
+---------------+---------+
| product_id    | int     |
| purchase_date | date    |
| units         | int     |
+---------------+---------+
UnitsSold 表没有主键,它可能包含重复项。
UnitsSold 表的每一行表示的是每种产品的出售日期,单位和产品 id。

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/average-selling-price
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

编写SQL查询以查找每种产品的平均售价。
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    |
+------------+---------------+-------+

Result table:
+------------+---------------+
| 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

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/average-selling-price
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

分析:首先要知道每个产品的销售总额,通过示例我们知道UnitsSold中的数据是每个产品在一段时间内售出的情况,所以 我们要知道总额就需要单价*总数。最后我们根据总数和总额就可以计算出来产品的平均售价。

# 每个产品的总数

SELECT

    product_id,

    sum( units ) 

FROM

    UnitsSold 

GROUP BY

    product_id

 # 计算产品的销售总额:单价*总数,每个产品在一段时间的销售总额

SELECT

    p.product_id,

    u.units * p.price AS sales 

FROM

    Prices p

    JOIN UnitsSold u ON u.product_id = p.product_id 

WHERE

    u.purchase_date BETWEEN p.start_date 

    AND p.end_date 

 # 计算每种产品的平均售价  通过子查询先获取产品的总数和销售总额,最后按照产品进行分组。ROUND()函数用于四舍五入 

SELECT

    product_id,

    ROUND( sum( sales )/ sum( units ), 2 ) average_price 

FROM

    (

    SELECT

        p.product_id,

        u.units * p.price AS sales, #计算总额

        u.units #个数

    FROM

        Prices p

        JOIN UnitsSold u ON u.product_id = p.product_id 

    WHERE

        u.purchase_date BETWEEN p.start_date 

        AND p.end_date 

    ) t 

GROUP BY

    product_id

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值