Algorithm/Programmers SQL

[MySQL] 프로그래머스 업그레이드 할 수 없는 아이템 구하기

제우제우 2024. 9. 15. 22:21

https://school.programmers.co.kr/learn/courses/30/lessons/273712

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

코딩테스트 연습 > IS NULL > 업그레이드 할 수 없는 아이템 구하기

 

문제 분석

난이도: LEVEL3

 

문제 요구사항

더 이상 업그레이드할 수 없는 아이템의 아이템 ID(ITEM_ID), 아이템 명(ITEM_NAME), 아이템의 희귀도(RARITY)를 출력하는 SQL 문을 작성해 주세요. 

이때 결과는 아이템 ID를 기준으로 내림차순 정렬해 주세요.

정답 코드

SELECT ITEM_ID, ITEM_NAME, RARITY
FROM  ITEM_INFO 
WHERE ITEM_ID NOT IN (SELECT DISTINCT PARENT_ITEM_ID
                      FROM ITEM_TREE
                      WHERE PARENT_ITEM_ID IS NOT NULL)
ORDER BY ITEM_ID DESC

 

ITEM_ID가 ITEM_TREE 테이블에서 PARENT_ITEM_ID로 있지 않는다면 해당 아이템은 더 이상 업그레이드 불가능하다.