力扣高频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小的值

相关推荐
️️(^~^)11 分钟前
触发器,存储过程
数据库
罗光记17 分钟前
Quantinuum 发布新型量子计算机“Helios“
数据库·经验分享·其他·百度·twitter
友友马36 分钟前
『 数据库 』MySQL索引深度解析:从数据结构到B+树的完整指南
数据库·mysql
SelectDB1 小时前
替换 ClickHouse,查询并发提升 7 倍!高途教育基于阿里云 SelectDB 构建秒级实时报表
数据库·apache
JamSlade1 小时前
优化用户体验的小点:乐观更新链路 双数据库查询
数据库·ux
一 乐1 小时前
个人博客|博客app|基于Springboot+微信小程序的个人博客app系统设计与实现(源码+数据库+文档)
java·前端·数据库·spring boot·后端·小程序·论文
小二·1 小时前
用 eBPF 实现 MySQL 慢查询实时追踪(终极实战版):零侵入、毫秒级、全上下文捕获
数据库·mysql·adb
云飞云共享云桌面2 小时前
三维设计办公资源如何共享集中和安全管控?
运维·服务器·数据库·安全·自动化·制造
百锦再3 小时前
大型省级政务平台采用金仓数据库(KingbaseES)
开发语言·数据库·后端·rust·eclipse