指定日期的产品价格Java
文章发布较早,内容可能过时,阅读注意甄别。
# 题目
产品数据表: Products
+---------------+---------+
| Column Name | Type |
+---------------+---------+
| product_id | int |
| new_price | int |
| change_date | date |
+---------------+---------+
(product_id, change_date) 是此表的主键(具有唯一值的列组合)。
这张表的每一行分别记录了 某产品 在某个日期 更改后 的新价格。
编写一个解决方案,找出在 2019-08-16 时全部产品的价格,假设所有产品在修改前的价格都是 10 。
以 任意顺序 返回结果表。
结果格式如下例所示。
示例 1:
输入:
Products 表:
+------------+-----------+-------------+
| product_id | new_price | change_date |
+------------+-----------+-------------+
| 1 | 20 | 2019-08-14 |
| 2 | 50 | 2019-08-14 |
| 1 | 30 | 2019-08-15 |
| 1 | 35 | 2019-08-16 |
| 2 | 65 | 2019-08-17 |
| 3 | 20 | 2019-08-18 |
+------------+-----------+-------------+
输出:
+------------+-------+
| product_id | price |
+------------+-------+
| 2 | 50 |
| 1 | 35 |
| 3 | 10 |
+------------+-------+
# 思路
left join
# 解法
select distinct p1.product_id, ifnull(p2.new_price,10) price from products p1
left join
(select *, row_number() over(partition by product_id order by change_date desc) rnk
from products
where change_date <= '2019-08-16') p2
on p1.product_id = p2.product_id and rnk=1
1
2
3
4
5
6
2
3
4
5
6
# 总结
- 分析出几种情况,然后分别对各个情况实现