SQL-leetcode—1164. 指定日期的产品价格

1164. 指定日期的产品价格

产品数据表: Products

±--------------±--------+
| Column Name | Type |
±--------------±--------+
| product_id | int |
| new_price | int |
| change_date | date |
±--------------±--------+
(product_id, change_date) 是此表的主键(具有唯一值的列组合)。
这张表的每一行分别记录了 某产品 在某个日期 更改后 的新价格。

编写一个解决方案,找出在 2019-08-16 时全部产品的价格,假设所有产品在修改前的价格都是 10 。

以 任意顺序 返回结果表。

结果格式如下例所示。

示例 1:

输入:
Products 表:
±-----------±----------±------------+
| product_id | new_price | change_date |
±-----------±----------±------------+
| 1 | 20 | 2019-08-14 |
| 2 | 50 | 2019-08-14 |
| 1 | 30 | 2019-08-15 |
| 1 | 35 | 2019-08-16 |
| 2 | 65 | 2019-08-17 |
| 3 | 20 | 2019-08-18 |
±-----------±----------±------------+
输出:
±-----------±------+
| product_id | price |
±-----------±------+
| 2 | 50 |
| 1 | 35 |
| 3 | 10 |
±-----------±------+

题解

找出在 2019-08-16 时全部产品的价格,假设所有产品在修改前的价格都是 10 。

  • 找出在 2019-08-16 时全部产品的价格 ,说明大于时间价格发生变化的话,这个就不考虑 – where
  • 假设所有产品在修改前的价格都是 10 也就是说要取全部产品,没有在这段时间改价的产品,价格是10, --ifnull

方法一 join+distinct

with tmp as (
    select product_id,new_price
    ,row_number() over(partition by product_id order by change_date desc ) as rn
    from Products where change_date <= '2019-08-16' 
)
select
    p1.product_id,ifnull(p2.new_price,10) as price
from (select distinct product_id from Products) p1
left join (
    select * from tmp where rn=1
) p2 on p1.product_id = p2.product_id

方法二:first_value函数

-- 查出来最近一次的价格
SELECT 
    product_id, 
    FIRST_VALUE(new_price) OVER(PARTITION BY product_id ORDER BY change_date DESC) AS price
FROM 
    Products
WHERE 
    change_date <= '2019-08-16'

UNION

-- 查询没有在这个时间段改价的产品和默认值
SELECT 
    DISTINCT product_id, 
    10 AS price
FROM 
    Products
WHERE 
    product_id NOT IN (SELECT product_id FROM Products WHERE change_date <= '2019-08-16')

emmm

FIRST_VALUE 使用指南

‌first_value函数‌是一个SQL分析函数,用于返回结果集中的第一个值。这个“第一个值”是通过ORDER BY语句确定的。如果在OVER子句中没有指定ORDER BY语句,则该函数返回结果集中的实际第一行。‌

FIRST_VALUE(expression) OVER (
PARTITION BY column1, column2,…
ORDER BY column3, column4,…
)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

掉进悬崖的狼

请博主喝杯奶茶

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值