반응형
문제 설명
다음은 식품의 정보를 담은 FOOD_PRODUCT 테이블입니다. FOOD_PRODUCT 테이블은 다음과 같으며 PRODUCT_ID, PRODUCT_NAME, PRODUCT_CD, CATEGORY, PRICE는 식품 ID, 식품 이름, 식품 코드, 식품분류, 식품 가격을 의미합니다.
Column name | Type | Nullable |
PRODUCT_ID | VARCHAR(10) | FALSE |
PRODUCT_NAME | VARCHAR(50) | FALSE |
PRODUCT_CD | VARCHAR(10) | TRUE |
CATEGORY | VARCHAR(10) | TRUE |
PRICE | NUMBER | TRUE |
문제
FOOD_PRODUCT 테이블에서 가격이 제일 비싼 식품의 식품 ID, 식품 이름, 식품 코드, 식품분류, 식품 가격을 조회하는 SQL문을 작성해주세요.
예시
FOOD_PRODUCT 테이블이 다음과 같을 때
PRODUCT_ID | PRODUCT_NAME | PRODUCT_CD | CATEGORY | PRICE |
P0018 | 맛있는고추기름 | CD_OL00008 | 식용유 | 6100 |
P0019 | 맛있는카놀라유 | CD_OL00009 | 식용유 | 5100 |
P0020 | 맛있는산초유 | CD_OL00010 | 식용유 | 6500 |
P0021 | 맛있는케첩 | CD_OL00001 | 소스 | 4500 |
P0022 | 맛있는마요네즈 | CD_OL00002 | 소스 | 4700 |
SQL을 실행하면 다음과 같이 출력되어야 합니다.
PRODUCT_ID | PRODUCT_NAME | PRODUCT_CD | CATEGORY | PRICE |
P0020 | 맛있는산초유 | CD_OL00010 | 식용유 | 6500 |
SELECT PRODUCT_ID, PRODUCT_NAME, PRODUCT_CD, CATEGORY, PRICE
FROM FOOD_PRODUCT
WHERE PRICE = (SELECT MAX(PRICE) FROM FOOD_PRODUCT);
동작 순서
> 서브쿼리
- SELECT MAX(PRICE) FROM FOOD_PRODUCT 서브쿼리가 먼저 실행된다.
이 서브쿼리는 'FOOD_PRODUCT' 테이블에서 최대 가격을 찾아 반환
> 메인 쿼리
- FOOD_PRODUCT 테이블에서
PRODUCT_ID, PRODUCT_NAME, PRODUCT_CD, CATEGORY, PRICE 컬럼들을 선택한다.
- WHERE 절에서는 PRICE가 서브쿼리에서 구한 최대 가격과 일치하는 행만 선택한다.
> 결과 반환
- 최종적으로 일치하는 행들이 선택되어 반환된다.
이는 'FOOD_PRODUCT' 테이블에서 가장 높은 가격을 가진 제품
반응형
'코딩테스트 > ORACLE' 카테고리의 다른 글
[프로그래머스/ORACLE] NULL 처리하기 (1) | 2024.04.18 |
---|---|
[프로그래머스/ORACLE] 이름이 없는 동물의 아이디 (1) | 2024.04.18 |
[프로그래머스/ORACLE] 조건에 맞는 회원수 구하기 (1) | 2024.04.18 |
[프로그래머스/ORACLE] 중성화 여부 파악하기 (1) | 2024.04.18 |
[프로그래머스/ORACLE] 카테고리 별 상품 개수 구하기 (2) | 2024.04.18 |