SQL/SQL test
[프로그래머스] 즐겨찾기가 가장 많은 식당 정보 출력하기
ISLA!
2023. 10. 7. 00:17
문제
REST_INFO 테이블에서 음식종류별로 즐겨찾기수가 가장 많은 식당의 음식 종류, ID, 식당 이름, 즐겨찾기수를 조회하는 SQL문을 작성해주세요. 이때 결과는 음식 종류를 기준으로 내림차순 정렬해주세요.
풀이
- 이 문제 풀이 순서는 '음식 종류별'로 가장 많은 '즐겨찾기 수'를 찾는 것이다. 그리고 이에 해당하는 식당의 정보를 가져와야 한다.
- where 절에서 서브쿼리를 사용하여 위의 조건을 설정할 수 있다.
- FOOD_TYPE 별로 FAVORITES의 최댓값을 구한다.
아래와 같은 결과가 나올 것이다.
- FOOD_TYPE 별로 FAVORITES의 최댓값을 구한다.
- 위의 내용에 해당하는 사항을 기준으로 필터링할 것이기 때문에, where 절에 두 개 컬럼 조건을 걸어주는 것이다.
- 마지막으로, order by 로 정렬을 지정한다.
SELECT FOOD_TYPE, REST_ID, REST_NAME, FAVORITES
FROM REST_INFO
WHERE (FOOD_TYPE, FAVORITES) in
(SELECT FOOD_TYPE, max(FAVORITES) from REST_INFO
group by FOOD_TYPE
)
order by FOOD_TYPE desc
728x90