문제
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
'SQL > SQL test' 카테고리의 다른 글
[프로그래머스] 식품분류별 가장 비싼 식품의 정보 조회하기 (1) | 2023.10.09 |
---|---|
[프로그래머스] 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 (0) | 2023.10.09 |
[프로그래머스] 조건에 맞는 사용자와 총 거래금액 조회하기 (0) | 2023.10.06 |
[프로그래머스] 오프라인/온라인 판매 데이터 통합하기 (0) | 2023.10.04 |
[프로그래머스] 조건에 부합하는 중고거래 댓글 조회하기 (0) | 2023.10.04 |