728x90
반응형
프로그래머스 SQL 고득점 키트 Lv.4
오프라인/온라인 판매 데이터 통합하기
문제
ONLINE_SALE
테이블과 OFFLINE_SALE
테이블에서 2022년 3월의 오프라인/온라인 상품 판매 데이터의 판매 날짜, 상품ID, 유저ID, 판매량을 출력하는 SQL문을 작성해주세요. OFFLINE_SALE
테이블의 판매 데이터의 USER_ID
값은 NULL 로 표시해주세요. 결과는 판매일을 기준으로 오름차순 정렬해주시고 판매일이 같다면 상품 ID를 기준으로 오름차순, 상품ID까지 같다면 유저 ID를 기준으로 오름차순 정렬해주세요.
풀이
✅ date_format(필드값, 형식)
: '%Y-%m-%d'로 지정하면 '2024-11-01'과 같이 변환된다.
✅ UNION 함수: 중복을 제거해서 합집합 (cf. UNION ALL: 중복을 제거하지 않고 합집합)
✅ NULL AS USER_ID
: 오프라인에서 판매된 데이터의 USER_ID
값은 모두 NULL로 표시해야 한다.
(SELECT date_format(SALES_DATE, '%Y-%m-%d') as SALES_DATE,
PRODUCT_ID, USER_ID, SALES_AMOUNT
FROM ONLINE_SALE
WHERE date_format(SALES_DATE, '%Y-%m') = '2022-03')
UNION
(SELECT date_format(SALES_DATE, '%Y-%m-%d') as SALES_DATE,
PRODUCT_ID, NULL AS USER_ID, SALES_AMOUNT
FROM OFFLINE_SALE
WHERE date_format(SALES_DATE, '%Y-%m') = '2022-03')
ORDER BY SALES_DATE ASC, PRODUCT_ID ASC, USER_ID ASC;
728x90
반응형