-
<프로그래머스> 5월 식품들의 총매출 조회하기코딩테스트/SQL 코딩테스트 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;
'코딩테스트 > SQL 코딩테스트' 카테고리의 다른 글
<프로그래머스> 없어진 기록 찾기 (1) 2023.12.21 <프로그래머스> 최댓값 구하기 (1) 2023.12.21 <프로그래머스> 식품분류별 가장 비싼 식품의 정보 조회하기 (1) 2023.12.21 <프로그래머스> 즐겨찾기가 가장 많은 식당 정보 출력하기 (0) 2023.12.21 <프로그래머스> 대여 기록이 존재하는 자동차 리스트 구하기 (1) 2023.12.21 - 문제 요구사항