프로그래머스 SQL
식품분류별 가장 비싼 식품의 정보 조회하기 (oracle)
kangyuseok
2024. 3. 12. 23:22
728x90
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
FOOD_PRODUCT 테이블에서 식품분류별로 가격이 제일 비싼 식품의 분류, 가격, 이름을 조회하는 SQL문을 작성해주세요.
이때 식품분류가 '과자', '국', '김치', '식용유'인 경우만 출력시켜 주시고 결과는 식품 가격을 기준으로 내림차순 정렬해주세요.
SELECT category, MAX(price) MAX_PRICE, product_name
from food_product
where category in ('과자', '국', '김치', '식용유')
group by category
order by price desc
처음에는 위와 같이 작성했지만, select의 product_name때문에 오류가 발생했다. group by 때문인거 같다.
즉, category와 MAX_PRICE만 나왔다.
여기서 self join을 사용하였다. 즉 먼저 category와 price가 MAX인 것을 걸러내는것이다.
select category, price MAX_PRICE, product_name
from food_product
where (category, price) in(
SELECT category, MAX(price)
from food_product
where category in ('과자', '국', '김치', '식용유')
group by category
)
order by price desc