[SQL] 프로그래머스 SQL 오프라인/온라인 판매 데이터 통합하기 풀이

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
반응형