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

相关推荐
小白量化14 小时前
聚宽策略分享-1年化98国九条后中小板微盘小改
大数据·数据库·人工智能·量化·qmt
有泽改之_20 小时前
leetcode146、OrderedDict与lru_cache
python·leetcode·链表
im_AMBER20 小时前
Leetcode 74 K 和数对的最大数目
数据结构·笔记·学习·算法·leetcode
DBA小马哥20 小时前
Oracle迁移实战:如何轻松跨越异构数据库的学习与技术壁垒
数据库·学习·oracle·信创·国产化平替
暮乘白帝过重山20 小时前
ArkTS ForEach 参数解析:组件与键值生成器
开发语言·数据库
一条咸鱼¥¥¥20 小时前
【运维经验】使用QQ邮箱SMTP服务器设置ssms计划任务完成时邮件发送
运维·服务器·经验分享·sql·sqlserver
长安er21 小时前
LeetCode 206/92/25 链表翻转问题-“盒子-标签-纸条模型”
java·数据结构·算法·leetcode·链表·链表翻转
Benmao⁢21 小时前
C语言期末复习笔记
c语言·开发语言·笔记·leetcode·面试·蓝桥杯
菜鸟plus+21 小时前
N+1查询
java·服务器·数据库
子夜江寒21 小时前
MySQL 表创建与数据导入导出
数据库·mysql