알고리즘(PS)/sql

[프로그래머스 MySql] 주문량이 많은 아이스크림들 조회하기

5353 2024. 2. 15. 02:44
반응형

 

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

 

프로그래머스

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

programmers.co.kr

문제 설명

7월 아이스크림 총 주문량과 상반기의 아이스크림 총 주문량을 더한 값이 큰 순서대로 상위 3개의 맛을 조회하는 SQL 문

 

7월 테이블 중복 처리(GROUP BY 와 SUM)

7월 테이블 칼럼과 상반기 테이블 칼럼 더하기

총주문량을 정렬 DESC

칼럼 3개 뽐기 LIMIT

 

정답 코드

-- 코드를 입력하세요
SELECT f.FLAVOR 
FROM  FIRST_HALF f
JOIN(
SELECT j.SHIPMENT_ID,j.FLAVOR ,  SUM(j.TOTAL_ORDER) AS TOTAL_ORDER
FROM  JULY j
GROUP BY j.FLAVOR ) AS JU
USING(SHIPMENT_ID)
ORDER BY f.TOTAL_ORDER + JU.TOTAL_ORDER DESC
LIMIT 3

 

 

오답 사유

1. 문제를 제대로 안 읽어서 중복을 처리하지 않았다.

GROUP BY를 통해 중복되는 컬럼들간의 합을 구한뒤 그 테이블과 JOIN해줘야한다.

 

2. 중간 중간 서브 쿼리의 이름을 정해주지 않아 오류가 떴다.

Every derived table must have its own alias

 

반응형