文章目录
- [力扣高频SQL 50题(基础版)第四十题](#力扣高频SQL 50题(基础版)第四十题)
-
- [1164. 指定日期的产品价格](#1164. 指定日期的产品价格)
力扣高频SQL 50题(基础版)第四十题
1164. 指定日期的产品价格
题目说明
产品数据表: Products
±--------------±--------+
| Column Name | Type |
±--------------±--------+
| product_id | int |
| new_price | int |
| change_date | date |
±--------------±--------+
(product_id, change_date) 是此表的主键(具有唯一值的列组合)。
这张表的每一行分别记录了 某产品 在某个日期 更改后 的新价格。
编写一个解决方案,找出在 2019-08-16
时全部产品的价格,假设所有产品在修改前的价格都是 10
。
以 任意顺序 返回结果表。
实现过程
准备数据
SQL
Create table If Not Exists Products (product_id int, new_price int, change_date date)
Truncate table Products
insert into Products (product_id, new_price, change_date) values ('1', '20', '2019-08-14')
insert into Products (product_id, new_price, change_date) values ('2', '50', '2019-08-14')
insert into Products (product_id, new_price, change_date) values ('1', '30', '2019-08-15')
insert into Products (product_id, new_price, change_date) values ('1', '35', '2019-08-16')
insert into Products (product_id, new_price, change_date) values ('2', '65', '2019-08-17')
insert into Products (product_id, new_price, change_date) values ('3', '20', '2019-08-18')
实现方式
SQL
select distinct product_id,
first_value(if(change_date<='2019-08-16',new_price,10)) over (partition by product_id order by (if(change_date<='2019-08-16',change_date,0))desc) price
from products;
结果截图
总结
FIRST_VALUE()函数
FIRST_VALUE()函数用于返回当前第一个值。
LAST_VALUE()函数
LAST_VALUE()函数用于返回当前最后一个值
NTH_VALUE()函数
LAST_VALUE()函数
LAST_VALUE()函数用于返回当前最后一个值
NTH_VALUE()函数
NTH_VALUE()函数用于返回有序行的第n小的值