본문 바로가기
Programmers(SQL 고득점 Kit)/LEVEL 4

[MySQL] 프로그래머스 - 오프라인/온라인 판매 데이터 통합하기 LEVEL 4

by DADA익선 2024. 12. 6.

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

 

프로그래머스

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

programmers.co.kr

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

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

 

문제 풀이 SQL CODE

1. FROM 절 서브쿼리 : UNION ALL을 통해 온라인/오프라인 통합 테이블 만들기

2. OFFLINE_SALE 테이블에는 USER_ID 컬럼이 없으므로 NULL값으로 표시한 USER_ID 컬럼 생성

3. DATE_FORMAT 사용 : 기존 SALES_DATE의 형태는 20xx-xx-xx 00:00:00 형식 > '%Y-%m-%d'로 변경

4. ORDER BY : SALES_DATE, PRODUCT_ID, USER_ID 순으로 오름차순 정

SELECT DATE_FORMAT(SALES_DATE,'%Y-%m-%d') AS SALES_DATE,PRODUCT_ID,USER_ID,SALES_AMOUNT
FROM
(SELECT USER_ID,PRODUCT_ID,SALES_AMOUNT, SALES_DATE FROM ONLINE_SALE
UNION ALL
SELECT NULL AS USER_ID, PRODUCT_ID, SALES_AMOUNT, SALES_DATE FROM OFFLINE_SALE) A
WHERE SALES_DATE BETWEEN "2022-03-01" AND "2022-03-31"
ORDER BY SALES_DATE, PRODUCT_ID, USER_ID;

 

 

 

다른 LEVEL 4 문제 보러가기


2024.12.05 - [분류 전체보기] - [MySQL] 프로그래머스 - 서울에 위치한 식당 목록 출력하기 LEVEL 4

 

[MySQL] 프로그래머스 - 서울에 위치한 식당 목록 출력하기 LEVEL 4

https://school.programmers.co.kr/learn/courses/30/lessons/131118 프로그래머스SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프programmers.co.kr서울에 위치한 식당 목

dakwk.tistory.com