난이도 : 하 (문제 이해도가 어려움, 책을 더 많이 읽을 것)
소요 시간 : 30분
문제 링크
https://school.programmers.co.kr/learn/courses/30/lessons/273711
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
문제 요약 및 설명
'ITEM_A'->'ITEM_B'와 같이 업그레이드가 가능할 때
'ITEM_A'를 'ITEM_B' 의 PARENT 아이템,
PARENT 아이템이 없는 아이템을 ROOT 아이템이라고 합니다.
예를 들어 'ITEM_A'->'ITEM_B'->'ITEM_C'와 같이 업그레이드가 가능한 아이템이 있다면
'ITEM_C'의 PARENT 아이템은 'ITEM_B'
'ITEM_B'의 PARENT 아이템은 'ITEM_A'
ROOT 아이템은 'ITEM_A'가 됩니다.
=> 즉, 게임 아이템은 업그레이드가 가능하다. 가장 최소의 게임아이템은 root 그리고 parent_item_id 에 따라 업그레이드가 될 수 있다.
문제
아이템의 희귀도가 'RARE'인 아이템들의 모든 다음 업그레이드 아이템의 아이템 ID(ITEM_ID),
아이템 명(ITEM_NAME), 아이템의 희귀도(RARITY)를 출력하는 SQL 문을 작성해 주세요.
이때 결과는 아이템 ID를 기준으로 내림차순 정렬주세요.
ITEM_INFO 테이블
0 ITEM_A RARE 10000
1 ITEM_B RARE 9000
2 ITEM_C LEGEND 11000
3 ITEM_D RARE 10000
4 ITEM_E RARE 12000
ITEM_TREE 테이블
ITEM_ID PARENT_ITEM_ID
0 NULL
1 0
2 0
3 1
4 1
아이템의 희귀도가 'RARE'인 아이템은 'ITEM_A', 'ITEM_B', 'ITEM_D', 'ITEM_E'
이 중 'ITEM_A' => 'ITEM_B', 'ITEM_C' 로 업그레이드가 가능하며
'ITEM_B' => 'ITEM_D' , 'ITEM_E' 로 업그레이드가 가능
따라서 정답은 아래와 같이 나와야 한다.
ITEM_ID ITEM_NAME RARITY
4 ITEM_E RARE
3 ITEM_D RARE
2 ITEM_C LEGEND
1 ITEM_B RARE
처음 코드
select i.ITEM_ID, i.ITEM_NAME, i.RARITY
from item_info as i
join item_tree as t on i.item_id = t.item_id
where i.rarity = 'RARE'
and i.item_id != t.parent_item_id
문제점 : info 테이블에서 업그레이드 결과를 내는것이 아니라, 더 이상 업그레이드가 되지 않는 아이템을 찾은 것.
해결 방안
- 우선, A로 예를 들자면
- info 테이블의 A 는 => tree 테이블의 parent_itme_id 를 통해 tree 테이블의 item_id 1 / 2 아이템으로 업그레이드 가능!
- 결국, 부모의 희귀도가 rare 인 자식을 찾으라는 말. ******
- 서브쿼리를 이용해서 rare where절로 삽입
정답 코드
SELECT T.ITEM_ID, I.ITEM_NAME, I.RARITY
FROM ITEM_INFO AS I
JOIN ITEM_TREE AS T ON I.ITEM_ID = T.ITEM_ID
WHERE T.PARENT_ITEM_ID IN (SELECT ITEM_ID
FROM ITEM_INFO
WHERE RARITY = 'RARE')
ORDER BY ITEM_ID DESC;
쿼리가 어렵다기 보다는 문제를 이해하는데 한 참 걸렸따..
'SQL' 카테고리의 다른 글
[프로그래머스][LV4] 식품분류별 가장 비싼 식품의 정보 조회하기 (0) | 2025.03.07 |
---|---|
[프로그래머스][LV3] 자동차 대여 기록에서 대여중 / 대여 가능 여부 구분하기 (0) | 2025.03.04 |
[Hacker Rank] SQL_Intermediate_Medium (Left join) (0) | 2025.02.02 |
[Hacker Rank] SQL_Intermediate_Medium (IF/암시적조인) (0) | 2025.02.01 |
[Hacker Rank] SQL_Intermediate_Medium (ROW_NUMBER/OVER) (0) | 2025.02.01 |