프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
문제 설계
서브쿼리에서 GROUP BY 음식 종류, SELECT MAX(FAVORITES) 하고 메인 쿼리에서 WHERE FAVORITES IN으로 처리
문제 풀이
오답
SELECT FOOD_TYPE,REST_ID,REST_NAME,MAX(FAVORITES) AS FAVORITES
FROM REST_INFO
GROUP BY FOOD_TYPE
ORDER BY FOOD_TYPE DESC;
정답
-- 코드를 입력하세요
SELECT FOOD_TYPE,REST_ID,REST_NAME,FAVORITES
FROM REST_INFO
WHERE FAVORITES IN (SELECT MAX(FAVORITES)
FROM REST_INFO
GROUP BY FOOD_TYPE)
GROUP BY FOOD_TYPE
ORDER BY FOOD_TYPE DESC;
정리
방식가능 여부이유
GROUP BY + MAX(FAVORITES)만 사용 | ❌ | REST_ID/NAME이 MAX값과 일치하지 않음 |
WHERE (FAVORITES) IN (...) | ✅ | 원하는 조건을 만족하는 전체 행을 정확히 추출 |
'코딩테스트 > SQL' 카테고리의 다른 글
[프로그래머스 LV4][SQL] 식품분류별 가장 비싼 식품의 정보 조회하기 (0) | 2025.04.12 |
---|---|
[프로그래머스 LV4][SQL] 언어별 개발자 분류하기 (1) | 2025.04.09 |
[프로그래머스 LV3][SQL] 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 (0) | 2025.04.05 |
[프로그래머스 LV3][SQL] 자동차 대여 기록에서 대여중 / 대여 가능 여부 구분하기 (0) | 2025.04.04 |
[프로그래머스 LV3][SQL] 조건에 맞는 사용자 정보 조회하기 (0) | 2025.04.03 |