[SQL 문제 풀이] Sales Analysis III (판매 분석 III)

Stupefyee's avatar
Jun 11, 2025
[SQL 문제 풀이] Sales Analysis III (판매 분석 III)
Sales Analysis III - LeetCode
Can you solve this real interview question? Sales Analysis III - Table: Product +--------------+---------+ | Column Name | Type | +--------------+---------+ | product_id | int | | product_name | varchar | | unit_price | int | +--------------+---------+ product_id is the primary key (column with unique values) of this table. Each row of this table indicates the name and the price of each product. Table: Sales +-------------+---------+ | Column Name | Type | +-------------+---------+ | seller_id | int | | product_id | int | | buyer_id | int | | sale_date | date | | quantity | int | | price | int | +-------------+---------+ This table can have duplicate rows. product_id is a foreign key (reference column) to the Product table. Each row of this table contains some information about one sale.   Write a solution to report the products that were only sold in the first quarter of 2019. That is, between 2019-01-01 and 2019-03-31 inclusive. Return the result table in any order. The result format is in the following example.   Example 1: Input: Product table: +------------+--------------+------------+ | product_id | product_name | unit_price | +------------+--------------+------------+ | 1 | S8 | 1000 | | 2 | G4 | 800 | | 3 | iPhone | 1400 | +------------+--------------+------------+ Sales table: +-----------+------------+----------+------------+----------+-------+ | seller_id | product_id | buyer_id | sale_date | quantity | price | +-----------+------------+----------+------------+----------+-------+ | 1 | 1 | 1 | 2019-01-21 | 2 | 2000 | | 1 | 2 | 2 | 2019-02-17 | 1 | 800 | | 2 | 2 | 3 | 2019-06-02 | 1 | 800 | | 3 | 3 | 4 | 2019-05-13 | 2 | 2800 | +-----------+------------+----------+------------+----------+-------+ Output: +-------------+--------------+ | product_id | product_name | +-------------+--------------+ | 1 | S8 | +-------------+--------------+ Explanation: The product with id 1 was only sold in the spring of 2019. The product with id 2 was sold in the spring of 2019 but was also sold after the spring of 2019. The product with id 3 was sold after spring 2019. We return only product 1 as it is the product that was only sold in the spring of 2019.
Sales Analysis III - LeetCode
notion image
2019년 1분기에만 판매된 제품을 보고할 수 있는 솔루션을 작성하세요. 즉, 2019-01-01과 2019-03-31 사이에 포함됩니다. 결과 테이블을 순서에 상관없이 반환하세요.
 

내가 작성한 쿼리

Oracle

SELECT P.product_id, P.product_name FROM Product P JOIN Sales S ON P.product_id = S.product_id GROUP BY P.product_id, P.product_name HAVING MIN(S.sale_date) >= TO_DATE('2019-01-01', 'YYYY-MM-DD') AND MAX(S.sale_date) <= TO_DATE('2019-03-31', 'YYYY-MM-DD');

MySQL

SELECT P.product_id, P.product_name FROM Product P JOIN Sales S ON P.product_id = S.product_id GROUP BY P.product_id, P.product_name HAVING MIN(S.sale_date) >= '2019-01-01' AND MAX(S.sale_date) <= '2019-03-31';

차이점

  • 날짜 비교를 위한 날짜 형식의 차이
Share article

stupefyee