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';
相关推荐
翔云1234567 小时前
MySQL主从库复制中,主库如何查找对应日志文件位置
数据库·mysql
Mr_star_galaxy8 小时前
【MySQL基础】视图和权限管理
数据库·mysql
lipiaoshuigood9 小时前
MySQL 数据出海之数据同步方案
数据库·mysql
笨蛋不要掉眼泪10 小时前
Nacos配置中心详解:核心用法、动态刷新与经典面试题解析
java·数据库·后端
@@神农10 小时前
PostgreSQL-SQL语句的执行过程(一)
数据库·sql·postgresql
Andy Dennis11 小时前
一文漫谈数据库存储之索引(B+, B-link, LSM tree等)
数据库·b+树·lsm-tree
CHANG_THE_WORLD11 小时前
字符串定义的汇编分析
汇编·数据库
数据知道12 小时前
PostgreSQL:如何通过progres_fdw跨库关联查询?
数据库·postgresql
v***570012 小时前
MYSQL 创建索引
数据库·mysql
heimeiyingwang12 小时前
大模型 RAG 技术原理与企业级落地实践
大数据·数据库·人工智能·架构