단의 개발 블로그

주문량이 많은 아이스크림들 조회하기 본문

Algorithm/SQL

주문량이 많은 아이스크림들 조회하기

danso 2024. 9. 5. 19:44

💡 문제설명

다음은 아이스크림 가게의 상반기 주문 정보를 담은 FIRST_HALF 테이블과 7월의 아이스크림 주문 정보를 담은 JULY 테이블입니다. FIRST_HALF 테이블 구조는 다음과 같으며, SHIPMENT_ID, FLAVOR, TOTAL_ORDER 각각 아이스크림 공장에서 아이스크림 가게까지의 출하 번호, 아이스크림 , 상반기 아이스크림 총주문량을 나타냅니다. FIRST_HALF 테이블의 기본 키는 FLAVOR입니다. FIRST_HALF테이블의 SHIPMENT_ID JULY테이블의 SHIPMENT_ID 외래 키입니다.

JULY 테이블 구조는 다음과 같으며, SHIPMENT_ID, FLAVOR, TOTAL_ORDER  각각 아이스크림 공장에서 아이스크림 가게까지의 출하 번호, 아이스크림 , 7 아이스크림 총주문량을 나타냅니다. JULY 테이블의 기본 키는 SHIPMENT_ID입니다. JULY테이블의 FLAVOR FIRST_HALF 테이블의 FLAVOR 외래 키입니다. 7월에는 아이스크림 주문량이 많아 같은 아이스크림에 대하여 서로 다른 공장에서 아이스크림 가게로 출하를 진행하는 경우가 있습니다. 경우 같은 맛의 아이스크림이라도 다른 출하 번호를 갖게 됩니다.

 

💡 문제

7 아이스크림 주문량과 상반기의 아이스크림 주문량을 더한 값이 순서대로 상위 3개의 맛을 조회하는 SQL 문을 작성해주세요.

 

예시

예를 들어 FIRST_HALF 테이블이 다음과 같고

JULY테이블이 다음과 같다면

 

7 아이스크림 총주문량과 상반기의 아이스크림 주문량을 더한 값이 순서대로 상위 3개의 맛을 조회하면 strawberry(520 + 220 + 3,100 = 3,840), mango(790 + 110 + 2,900 = 3,800), chocolate(520 + 3,200 = 3,720) 순입니다. 따라서 SQL 문을 실행하면 다음과 같이 나와야 합니다.

 

 풀이

아래와 같이 풀었는데 뭔가 코드가 지저분했다. 다른 사람들의 풀이를 참고해보니 컬럼이 모두 똑같아서 UNION ALL로 모두 가져오고 푸는 방법이 제일 깔끔해보였다. 그래서 아래 코드를

SELECT A.FLAVOR
FROM 
    (   
        SELECT FH.FLAVOR, FH.TOTAL_ORDER + J.TOTAL_ORDER as TOTAL_ORDER 
        FROM FIRST_HALF FH 
            LEFT JOIN 
            (
                SELECT FLAVOR, SUM(TOTAL_ORDER) as TOTAL_ORDER FROM JULY GROUP BY FLAVOR
            ) J ON FH.FLAVOR = J.FLAVOR
        GROUP BY FH.FLAVOR
        ORDER BY TOTAL_ORDER DESC
        LIMIT 3
    ) A

 

이렇게 변경했다.

SELECT FLAVOR
FROM
    (
        SELECT FLAVOR, TOTAL_ORDER
        FROM FIRST_HALF
        UNION ALL
        SELECT FLAVOR, TOTAL_ORDER
        FROM JULY
    ) A
GROUP BY FLAVOR
ORDER BY SUM(TOTAL_ORDER) DESC
LIMIT 3

 

출처

https://school.programmers.co.kr/learn/challenges?tab=sql_practice_kit