力扣高频SQL 50题(基础版)第四十题之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小的值

相关推荐
圣保罗的大教堂10 分钟前
leetcode 2799. 统计完全子数组的数目 中等
leetcode
SsummerC17 分钟前
【leetcode100】组合总和Ⅳ
数据结构·python·算法·leetcode·动态规划
施嘉伟42 分钟前
Oracle 11g RAC ASM磁盘组剔盘、加盘实施过程
数据库·oracle
YuCaiH1 小时前
数组理论基础
笔记·leetcode·c·数组
2301_807611491 小时前
77. 组合
c++·算法·leetcode·深度优先·回溯
橘猫云计算机设计2 小时前
springboot基于hadoop的酷狗音乐爬虫大数据分析可视化系统(源码+lw+部署文档+讲解),源码可白嫖!
数据库·hadoop·spring boot·爬虫·python·数据分析·毕业设计
SsummerC2 小时前
【leetcode100】零钱兑换Ⅱ
数据结构·python·算法·leetcode·动态规划
卓怡学长2 小时前
w304基于HTML5的民谣网站的设计与实现
java·前端·数据库·spring boot·spring·html5
冰^3 小时前
MySQL VS SQL Server:优缺点全解析
数据库·数据仓库·redis·sql·mysql·json·数据库开发
电商数据girl3 小时前
产品经理对于电商接口的梳理||电商接口文档梳理与接入
大数据·数据库·python·自动化·产品经理