✨APS (Algorithm Problem Solving)/프로그래머스 SQL

[프로그래머스 SQL] 상품 별 오프라인 매출 구하기 / 오라클(Oracle)

Nyan cat 2022. 10. 17. 16:15

 

📜 문제 설명

다음은 어느 의류 쇼핑몰에서 판매중인 상품들의 상품 정보를 담은 PRODUCT 테이블과 오프라인 상품 판매 정보를 담은 OFFLINE_SALE 테이블 입니다. PRODUCT 테이블은 아래와 같은 구조로 PRODUCT_ID, PRODUCT_CODE, PRICE는 각각 상품 ID, 상품코드, 판매가를 나타냅니다.

 

Column name Type Nullable
PRODUT_ID INTEGER FALSE
PRODUT_CODE VARCHAR(8) FALSE
PRICE INTEGER FALSE

 

상품 별로 중복되지 않는 8자리 상품코드 값을 가지며, 앞 2자리는 카테고리 코드를 의미합니다.

 

OFFLINE_SALE 테이블은 아래와 같은 구조로 되어있으며 OFFLINE_SALE_ID, PRODUCT_ID, SALES_AMOUNT, SALES_DATE는 각각 오프라인 상품 판매 ID, 상품 ID, 판매량, 판매일을 나타냅니다.

Column name Type Nullable
OFFLINE_SALE_ID INTEGER FALSE
PRODUT_ID INTEGER FALSE
SALES_AMOUNT INTEGER FALSE
SALES_DATE DATE FALSE

동일한 날짜, 상품 ID 조합에 대해서는 하나의 판매 데이터만 존재합니다.

❓ 문제

PRODUCT 테이블과 OFFLINE_SALE 테이블에서 상품코드 별 매출액(판매가 * 판매량) 합계를 출력하는 SQL문을 작성해주세요.

결과는 매출액을 기준으로 내림차순 정렬해주시고 매출액이 같다면 상품코드를 기준으로 오름차순 정렬해주세요.

 

🔗 문제 링크

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

 

프로그래머스

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

programmers.co.kr

 

💡 문제 풀이

두 테이블을 조인해서 풀 수 있는 문제이다.

- PROUCT 테이블과 OFFLINE_SALE 테이블을 PRODUCT_ID 기준으로 조인한다.

- PRODUCT 테이블의 PRICE, OFFLINE_SALE 테이블의 SALES_AMOUNT를 곱한 값을 SUM

- PRODUCT_CODE 기준으로 그룹화

 

SELECT p.product_code, SUM(p.price * o.sales_amount) AS sales
FROM product p JOIN offline_sale o
ON p.product_id = o.product_id
GROUP BY p.product_code
ORDER BY sales DESC, product_code
반응형