34 - 指定日期的产品价格(高频 SQL 50 题基础版)

34 - 指定日期的产品价格


sql 复制代码
-- row_number(行号) 生成连续的序号,不考虑分数相同
-- 在'2019-08-16'之前改的价格,使用最近一期的日期,没有在'2019-08-16'之前改的价格,默认价格为10
select 
    t.product_id, 
    t.new_price as price
from 
    (
        select 
            *,
            row_number() over (PARTITION BY product_id order by change_date desc) as row_num
        from 
            Products
        where 
            change_date<='2019-08-16') 
    as t
where 
    t.row_num=1
union
-- 没有在'2019-08-16'之前改的价格,默认价格为10
select 
    product_id, 10 as price 
from 
    Products 
group by 
    product_id
having 
    min(change_date)>'2019-08-16';
相关推荐
coderlin_1 分钟前
Langgraph项目三 agent搭建
java·数据库·redis
xyx-3v4 分钟前
信号量(二进制/计数)
java·linux·数据库
u01102251212 分钟前
HTML5多媒体资源动态替换Source标签的刷新机制
jvm·数据库·python
云祺vinchin16 分钟前
“十五五”引领灾备升级,数字化安全建设如何合规落地?
网络·数据库·安全·kubernetes·数据安全·容灾备份
当战神遇到编程18 分钟前
关系型数据库设计基础:约束、三大范式、表关系与表设计流程
数据库
其实防守也摸鱼26 分钟前
《SQL注入进阶实验:基于sqli-Labs的报错注入(Error-Based Injection)实战解析》
网络·数据库·sql·安全·网络安全·sql注入·报错注入
Ting.~27 分钟前
软件设计师备考笔记【day3】-数据库
数据库·笔记
Bert.Cai28 分钟前
MySQL FLOOR()函数详解
数据库·mysql
小碗羊肉36 分钟前
【MySQL | 第七篇】索引
数据库·mysql
juniperhan39 分钟前
Flink 系列第20篇:Flink SQL 语法全解:从 DDL 到 DML,窗口、聚合、列转行一网打尽
大数据·数据仓库·分布式·sql·flink