본문 바로가기
SQL/SQL test

[프로그래머스] 즐겨찾기가 가장 많은 식당 정보 출력하기

by ISLA! 2023. 10. 7.

 

문제

REST_INFO 테이블에서 음식종류별로 즐겨찾기수가 가장 많은 식당의 음식 종류, ID, 식당 이름, 즐겨찾기수를 조회하는 SQL문을 작성해주세요. 이때 결과는 음식 종류를 기준으로 내림차순 정렬해주세요.

 

 

풀이

  • 이 문제 풀이 순서는 '음식 종류별'로 가장 많은 '즐겨찾기 수'를 찾는 것이다. 그리고 이에 해당하는 식당의 정보를 가져와야 한다.
  • where 절에서 서브쿼리를 사용하여 위의 조건을 설정할 수 있다.
    • 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