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 했다.
'MYSQL > 프로그래머스 LV04' 카테고리의 다른 글
그룹별 조건에 맞는 식당 목록 출력하기 (0) | 2025.03.24 |
---|---|
년, 월, 성별 별 상품 구매 회원 수 구하기 (0) | 2025.03.24 |
취소되지 않은 진료 예약 조회하기 (0) | 2025.03.21 |
언어별 개발자 분류하기 (0) | 2025.03.20 |
자동차 대여 기록 별 대여 금액 구하기 (0) | 2025.03.20 |