https://school.programmers.co.kr/learn/courses/30/lessons/131537
오프라인/온라인 판매 데이터 통합하기 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
'Programmers(SQL 고득점 Kit) > LEVEL 4' 카테고리의 다른 글
[MySQL] 프로그래머스 - 년, 월, 성별 별 상품 구매 회원 수 구하기 LEVEL 4 (0) | 2024.12.18 |
---|---|
[MySQL] 프로그래머스 - 식품분류별 가장 비싼 식품의 정보 조회하기 LEVEL 4 (0) | 2024.12.11 |
[MySQL] 프로그래머스 - 저자 별 카테고리 별 매출액 집계하기 LEVEL 4 (0) | 2024.12.11 |
[MySQL] 프로그래머스 - 특정 세대의 대장균 찾기 LEVEL 4 (0) | 2024.12.10 |
[MySQL] 프로그래머스 - 서울에 위치한 식당 목록 출력하기 LEVEL 4 (0) | 2024.12.05 |