Description
Table: Products
+---------------+---------+ | Column Name | Type | +---------------+---------+ | product_id | int | | new_price | int | | change_date | date | +---------------+---------+ (product_id, change_date) is the primary key (combination of columns with unique values) of this table. Each row of this table indicates that the price of some product was changed to a new price at some date.
Initially, all products have price 10.
Write a solution to find the prices of all products on the date 2019-08-16.
Return the result table in any order.
The result format is in the following example.
Β
Example 1:
Input: Products table: +------------+-----------+-------------+ | 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 | +------------+-----------+-------------+ Output: +------------+-------+ | product_id | price | +------------+-------+ | 2 | 50 | | 1 | 35 | | 3 | 10 | +------------+-------+
Solution
PostgreSQL
-- Write your PostgreSQL query statement below
select p.product_id, p.new_price as price
from products p, (
    select p.product_id, max(p.change_date) as change_date
    from products p
    where p.change_date <= '2019-08-16'
    group by p.product_id
) as p2
where p.product_id = p2.product_id and p.change_date = p2.change_date
UNION
select p.product_id, 10 as price
from products p
group by p.product_id
having (min(p.change_date) > '2019-08-16');