1164. Product Price at a Given Date - Detailed Explanation
Problem Statement
Table Products:
+-------------+---------+-------------+  
| Column Name | Type    |  
+-------------+---------+-------------+  
| product_id  | int     |  
| new_price   | int     |  
| change_date | date    |  
+-------------+---------+  
- (product_id, change_date)is the primary key.
- Each row records that at change_date, the product’s price became new_price.
 Write a query to report the price of every product on 2019-08-16. If a product has no price change on or before that date, its price is 10. Return(product_id, price)in any order citeturn0search2.
Examples
Given:
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  |  
+------------+-----------+-------------+  
Output:
+------------+-------+  
| product_id | price |  
+------------+-------+  
| 2          | 50    |  
| 1          | 35    |  
| 3          | 10    |  
+------------+-------+  
Approach 1 — Subquery + Join
- List all distinct products in T.
- In P, for each product find the maxchange_date ≤ '2019-08-16'and take itsnew_price.
- Left join TwithP, usingCOALESCE(orIFNULL) to default missing prices to 10.
WITH T AS ( SELECT DISTINCT product_id FROM Products ), P AS ( SELECT product_id, new_price AS price FROM Products WHERE (product_id, change_date) IN ( SELECT product_id, MAX(change_date) AS change_date FROM Products WHERE change_date <= '2019-08-16' GROUP BY product_id ) ) SELECT T.product_id, COALESCE(P.price, 10) AS price FROM T LEFT JOIN P ON T.product_id = P.product_id;
Approach 2 — Window Function
- In Ranked, keep only changes on or before '2019-08-16' and rank them per product bychange_date DESC.
- In Latest, select rows wherern = 1(the latest change).
- Left join all distinct products with Latest, defaulting to 10 if missing.
WITH Ranked AS ( SELECT product_id, new_price, ROW_NUMBER() OVER ( PARTITION BY product_id ORDER BY change_date DESC ) AS rn FROM Products WHERE change_date <= '2019-08-16' ), Latest AS ( SELECT product_id, new_price AS price FROM Ranked WHERE rn = 1 ) SELECT p.product_id, COALESCE(L.price, 10) AS price FROM ( SELECT DISTINCT product_id FROM Products ) AS p LEFT JOIN Latest AS L ON p.product_id = L.product_id;
Complexity Analysis
- Time: O(N log N) due to sorting/grouping by change_datefor N rows.
- Space: O(N) for intermediate CTEs and indexes.
Python Code
Python3
Python3
. . . .
Java Code
Java
Java
. . . .
Common Mistakes
- Forgetting the date filter (change_date ≤ '2019-08-16') in subqueries or windowing.
- Omitting the LEFT JOIN, which drops products with no changes.
- Failing to apply COALESCE/IFNULL, thus returning NULL instead of default 10.
Edge Cases
- A product with no change before or on the date → price 10.
- Multiple changes on the same day (primary key prevents this).
- Only one product in the table.
Alternative Variations
- Exact date only (exclude changes after that date).
- Price of all products over a date range.
- Extend to handle future price projections.
Related Problems
TAGS
leetcode
CONTRIBUTOR
Design Gurus Team
-
GET YOUR FREE
Coding Questions Catalog
Boost your coding skills with our essential coding questions catalog.
Take a step towards a better tech career now!
Explore Answers
41. First Missing Positive - Detailed Explanation
Learn to solve Leetcode 41. First Missing Positive with multiple approaches.
151. Reverse Words in a String - Detailed Explanation
Learn to solve Leetcode 151. Reverse Words in a String with multiple approaches.
2168. Unique Substrings With Equal Digit Frequency - Detailed Explanation
Learn to solve Leetcode 2168. Unique Substrings With Equal Digit Frequency with multiple approaches.
2663. Lexicographically Smallest Beautiful String - Detailed Explanation
Learn to solve Leetcode 2663. Lexicographically Smallest Beautiful String with multiple approaches.
181. Employees Earning More Than Their Managers - Detailed Explanation
Learn to solve Leetcode 181. Employees Earning More Than Their Managers with multiple approaches.
347. Top K Frequent Elements - Detailed Explanation
Learn to solve Leetcode 347. Top K Frequent Elements with multiple approaches.
Related Courses
Grokking the Coding Interview: Patterns for Coding Questions
Grokking the Coding Interview Patterns in Java, Python, JS, C++, C#, and Go. The most comprehensive course with 476 Lessons.
4.6
(69,299 learners)
$197
New

Grokking Modern AI Fundamentals
Master the fundamentals of AI today to lead the tech revolution of tomorrow.
3.9
(1,107 learners)
$78
Grokking Data Structures & Algorithms for Coding Interviews
Unlock Coding Interview Success: Dive Deep into Data Structures and Algorithms.
4
(26,683 learners)
$78
One-Stop Portal For Tech Interviews.
Copyright © 2025 Design Gurus, LLC. All rights reserved.