본문 바로가기
MYSQL/프로그래머스 LV04

오프라인/온라인 판매 데이터 통합하기

by 수스리 2025. 3. 21.

https://school.programmers.co.kr/learn/courses/30/lessons/131537

 

프로그래머스

SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프

programmers.co.kr

 

 

문제

 ONLINE_SALE 테이블과 OFFLINE_SALE 테이블에서 2022년 3월의 오프라인/온라인 상품 판매 데이터의 판매 날짜, 상품ID, 유저ID, 판매량을 출력하는 SQL문을 작성해주세요. OFFLINE_SALE 테이블의 판매 데이터의 USER_ID 값은 NULL 로 표시해주세요. 결과는 판매일을 기준으로 오름차순 정렬해주시고 판매일이 같다면 상품 ID를 기준으로 오름차순, 상품ID까지 같다면 유저 ID를 기준으로 오름차순 정렬해주세요.

 

쿼리

WITH TEMP1 AS (SELECT
       *
FROM
        ONLINE_SALE
WHERE
        year(sales_date) = 2022 AND month(sales_date) = 3
),
TEMP2 AS (
SELECT
    *, NULL AS USER_ID
FROM
    OFFLINE_SALE
WHERE
        year(sales_date) = 2022 AND month(sales_date) = 3
),
TEMP3 AS(
SELECT 
    DATE_FORMAT(sales_date, "%Y-%m-%d") AS SALES_DATE, PRODUCT_ID, USER_ID, SALES_AMOUNT
FROM
    TEMP1
UNION ALL
SELECT
    DATE_FORMAT(sales_date, "%Y-%m-%d") AS sales_date, PRODUCT_ID, USER_ID, SALES_AMOUNT
FROM TEMP2
)
SELECT *
FROM TEMP3
ORDER BY sales_date, product_id, user_id

 

갠적으로 난이도가 있었다. UNION_ALL을 써야 하는 건 알겠는데 어떻게 쓸지 감이 안왔다. OFFLINE_SALE 테이블은 user_id가 없는데 이걸 처리하는게 힘들었다. 겨우 우겨넣는 식으로 user_id에 NULL값을 넣고 UNION ALL 했다.