当前位置: 首页 > article >正文

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,…
)


http://www.kler.cn/a/518554.html

相关文章:

  • C++——list的了解和使用
  • 为什么在编程中cast有强制类型转换的意思?
  • leetcode_链表 876.链表的中间节点
  • 网盘资源查找工具---AI功能
  • 【Linux线程总结】VMA ELF 地址转换 同步和互斥 条件变量 PC模型 循环队列 POSIX信号量 线程池
  • 微信小程序-点餐(美食屋)02开发实践
  • 【GoLang】利用validator包实现服务端参数校验时自定义错误信息
  • 星动纪元ERA-42:端到端原生机器人大模型的革命性突破
  • Excel打印技巧
  • 【2024年华为OD机试】 (E卷,200分) - 寻找符合要求的最长子串(JavaScriptJava PythonC/C++)
  • HTML入门知识
  • java+vue项目部署记录
  • css命名规范——BEM
  • Java 中的设计模式:经典与现代实践
  • 【RK3588嵌入式图形编程】-SDL2-检测和管理错误
  • web速览
  • 【MARK】Cline配合FreeAPI,再薅亿点点token
  • [央企大赛 2025] pwn
  • http的请求体各项解析
  • 【Qt 常用控件】显示类控件1(QLabel)
  • tensorflow,cuda,cudnn,pycharm安装踩坑过程记录
  • 什么时候用MPP,什么时候用TiDB?
  • PyTorch 模型 浅读
  • WPS按双字段拆分工作表到独立工作簿-Excel易用宝
  • 深度解读:Facebook 区块链技术架构与应用前景
  • 升级到Mac15.1后pod install报错