1. 문제
다음은 식품의 정보를 담은 FOOD_PRODUCT 테이블입니다. FOOD_PRODUCT 테이블은 다음과 같으며 PRODUCT_ID, PRODUCT_NAME, PRODUCT_CD, CATEGORY, PRICE는 식품 ID, 식품 이름, 식품코드, 식품분류, 식품 가격을 의미합니다.

FOOD_PRODUCT 테이블에서 식품분류별로 가격이 제일 비싼 식품의 분류, 가격, 이름을 조회하는 SQL문을 작성해주세요. 이때 식품분류가 '과자', '국', '김치', '식용유'인 경우만 출력시켜 주시고 결과는 식품 가격을 기준으로 내림차순 정렬해주세요.
2. 풀이 (조인 연산 안에 서브 쿼리 활용)
SELECT A.CATEGORY, A.MAX_PRICE, FOOD_PRODUCT.PRODUCT_NAME
FROM (
SELECT CATEGORY, MAX(PRICE) AS MAX_PRICE
FROM FOOD_PRODUCT
WHERE CATEGORY IN ('과자', '국', '김치', '식용유')
GROUP BY CATEGORY
) A -- 카테고리 별로 가장 높은 금액을 뽑아오는 서브 쿼리
JOIN FOOD_PRODUCT ON
A.MAX_PRICE = FOOD_PRODUCT.PRICE
AND A.CATEGORY = FOOD_PRODUCT.CATEGORY
-- 가장 높은 금액과 동일한 카테고리의 상품을 가져오기 위해 조인 수행
ORDER BY MAX_PRICE DESC
3. 다른 풀이 (서브 쿼리만 활용)
SELECT CATEGORY,
PRICE AS 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 MAX_PRICE DESC;
'DB > Oracle' 카테고리의 다른 글
[Oracle] Programmers - 자동차 대여 기록에서 대여 중 / 대여 가능 여부 구분하기 (0) | 2025.01.30 |
---|---|
[Oracle] Programmers - 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 (0) | 2025.01.30 |
[Oracle] Programmers - 저자 별 카테고리 별 매출액 집계하기 (0) | 2025.01.29 |
[Oracle] Programmers - 중복 제거하기 (0) | 2025.01.29 |
[Oracle] Programmers - 가격이 제일 비싼 식품의 정보 출력하기 (0) | 2025.01.29 |
1. 문제
다음은 식품의 정보를 담은 FOOD_PRODUCT 테이블입니다. FOOD_PRODUCT 테이블은 다음과 같으며 PRODUCT_ID, PRODUCT_NAME, PRODUCT_CD, CATEGORY, PRICE는 식품 ID, 식품 이름, 식품코드, 식품분류, 식품 가격을 의미합니다.

FOOD_PRODUCT 테이블에서 식품분류별로 가격이 제일 비싼 식품의 분류, 가격, 이름을 조회하는 SQL문을 작성해주세요. 이때 식품분류가 '과자', '국', '김치', '식용유'인 경우만 출력시켜 주시고 결과는 식품 가격을 기준으로 내림차순 정렬해주세요.
2. 풀이 (조인 연산 안에 서브 쿼리 활용)
SELECT A.CATEGORY, A.MAX_PRICE, FOOD_PRODUCT.PRODUCT_NAME
FROM (
SELECT CATEGORY, MAX(PRICE) AS MAX_PRICE
FROM FOOD_PRODUCT
WHERE CATEGORY IN ('과자', '국', '김치', '식용유')
GROUP BY CATEGORY
) A -- 카테고리 별로 가장 높은 금액을 뽑아오는 서브 쿼리
JOIN FOOD_PRODUCT ON
A.MAX_PRICE = FOOD_PRODUCT.PRICE
AND A.CATEGORY = FOOD_PRODUCT.CATEGORY
-- 가장 높은 금액과 동일한 카테고리의 상품을 가져오기 위해 조인 수행
ORDER BY MAX_PRICE DESC
3. 다른 풀이 (서브 쿼리만 활용)
SELECT CATEGORY,
PRICE AS 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 MAX_PRICE DESC;
'DB > Oracle' 카테고리의 다른 글
[Oracle] Programmers - 자동차 대여 기록에서 대여 중 / 대여 가능 여부 구분하기 (0) | 2025.01.30 |
---|---|
[Oracle] Programmers - 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 (0) | 2025.01.30 |
[Oracle] Programmers - 저자 별 카테고리 별 매출액 집계하기 (0) | 2025.01.29 |
[Oracle] Programmers - 중복 제거하기 (0) | 2025.01.29 |
[Oracle] Programmers - 가격이 제일 비싼 식품의 정보 출력하기 (0) | 2025.01.29 |