코딩테스트/SQL 코딩테스트

<프로그래머스> 5월 식품들의 총매출 조회하기

배또가또 2023. 12. 21. 13:39

출처 : https://school.programmers.co.kr/learn/courses/30/lessons/131117

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 


  • 문제 요구사항
    • FOOD_PRODUCT와 FOOD_ORDER 테이블에서
    • 생산일자가 2022년 5월인 식품들의 식품 ID, 식품 이름, 총 매출을 조회하는 SQL문을 작성 
    • 결과는 총 매출을 기준으로 내림차순 정렬
    • 총 매출이 같다면 식품 ID를 기준으로 오름차순 정렬

 

총매출을 알기 위해서는 AMOUNT와 PRICE를 곱해주어야하기  때문에 FOOD_PRODUCT와 FOOD_ORDER 테이블을 내부 조인해야한다. 조회할 때 2022년 5월의 데이터만 한정해주는 조건을 넣어야하고 

 

PRODUCT의 전체 총량을 위해 GROUP BY한 상태에서 SUM()으로 각 식품 별로 전체 판매량을 알아내는 서브쿼리를 작성 후 해당 조회 결과를 테이블로 하여 총 매출을 알아낼 수 있다.


1) Oracle

SELECT PRODUCT_ID, 
       PRODUCT_NAME, 
       SUM_AMOUNT * PRICE AS TOTAL_SALES
FROM 
(
    SELECT P.PRODUCT_ID,
           P.PRODUCT_NAME, 
           P.PRICE,
           SUM(O.AMOUNT) AS SUM_AMOUNT
    FROM FOOD_PRODUCT P INNER JOIN FOOD_ORDER O ON P.PRODUCT_ID = O.PRODUCT_ID
    WHERE TO_CHAR(O.PRODUCE_DATE, 'YYYY-MM') = '2022-05'
    GROUP BY P.PRODUCT_ID, P.PRODUCT_NAME, P.PRICE
) A
ORDER BY TOTAL_SALES DESC, PRODUCT_ID;

2) MySQL

SELECT PRODUCT_ID, 
       PRODUCT_NAME, 
       SUM_AMOUNT * PRICE AS TOTAL_SALES
FROM 
(
    SELECT P.PRODUCT_ID,
           P.PRODUCT_NAME, 
           P.PRICE,
           SUM(O.AMOUNT) AS SUM_AMOUNT
    FROM FOOD_PRODUCT P INNER JOIN FOOD_ORDER O ON P.PRODUCT_ID = O.PRODUCT_ID
    WHERE DATE_FORMAT(O.PRODUCE_DATE, '%Y-%m') = '2022-05'
    GROUP BY 1
) A
ORDER BY 3 DESC, 1;