[MySQL] 다중 JOIN, ON 조건

lazy_h·2026년 1월 5일

MySQL 다루기

목록 보기
8/18
post-thumbnail

(※개인 공부 목적의 게시물입니다.)


프로그래머스 > sql > select > 업그레이드 된 아이템 구하기

문제 바로가기


<문제설명>

어느 한 게임에서 사용되는 아이템들은 업그레이드가 가능합니다.
'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'가 됩니다.

다음은 해당 게임에서 사용되는 아이템 정보를 담은 ITEM_INFO 테이블과 아이템 관계를 나타낸 ITEM_TREE 테이블입니다.

ITEM_INFO 테이블은 다음과 같으며, ITEM_ID, ITEM_NAME, RARITY, PRICE는 각각 아이템 ID, 아이템 명, 아이템의 희귀도, 아이템의 가격을 나타냅니다.

Column nameTypeNullable
ITEM_IDINTEGERFALSE
ITEM_NAMEVARCHAR(N)FALSE
RARITYINTEGERFALSE
PRICEINTEGERFALSE

ITEM_TREE 테이블은 다음과 같으며, ITEM_ID, PARENT_ITEM_ID는 각각 아이템 ID, PARENT 아이템의 ID를 나타냅니다.

Column nameTypeNullable
ITEM_IDINTEGERFALSE
PARENT_ITEM_IDINTEGERTRUE

단, 각 아이템들은 오직 하나의 PARENT 아이템 ID를 가지며, ROOT 아이템의 PARENT 아이템 ID는 NULL 입니다.

ROOT 아이템이 없는 경우는 존재하지 않습니다.

<문제>

아이템의 희귀도가 'RARE'인 아이템들의 모든 다음 업그레이드 아이템아이템 ID(ITEM_ID), 아이템 명(ITEM_NAME), 아이템의 희귀도(RARITY)를 출력하는 SQL 문을 작성해 주세요.
이때 결과는 아이템 ID를 기준으로 내림차순 정렬주세요.


<예시>

예를 들어 ITEM_INFO 테이블이 다음과 같고

ITEM_IDITEM_NAMERARITYPRICE
0ITEM_ARARE10000
1ITEM_BRARE9000
2ITEM_CLEGEND11000
3ITEM_DRARE10000
4ITEM_ERARE12000

ITEM_TREE 테이블이 다음과 같다면

ITEM_IDPARENT_ITEM_ID
0NULL
10
20
31
41

아이템의 희귀도가 'RARE'인 아이템은 'ITEM_A', 'ITEM_B', 'ITEM_D', 'ITEM_E' 입니다.
이 중 'ITEM_A''ITEM_B', 'ITEM_C' 로 업그레이드가 가능하며
'ITEM_B''ITEM_D' , 'ITEM_E' 로 업그레이드가 가능합니다.
'ITEM_D' 와 'ITEM_E'더 이상 업그레이드가 가능하지 않습니다.

따라서 결과는 다음과 같이 나와야 합니다.

ITEM_IDITEM_NAMERARITY
4ITEM_ERARE
3ITEM_DRARE
2ITEM_CLEGEND
1ITEM_BRARE

<풀이코드>

SELECT C.ITEM_ID, C.ITEM_NAME, C.RARITY
FROM ITEM_INFO P JOIN ITEM_TREE T 
	ON P.ITEM_ID = T.PARENT_ITEM_ID
	JOIN ITEM_INFO C
    ON T.ITEM_ID = C.ITEM_ID
WHERE P.RARITY = 'RARE'
ORDER BY C.ITEM_ID DESC;

<설명>

  • FROM ITEM_INFO P JOIN ITEM_TREE T 
    	ON P.ITEM_ID = T.PARENT_ITEM_ID

-> merge함수를 사용하여 join결과를 출력해봄

: PARENT 아이템의 업그레이트 아이템을 ID로 알 수 있음
1. 아이템 A의 업그레이드 아이템의 ID는 1, 2
2. 아이템 B의 업그레이트 아이템의 ID는 3, 4

  • JOIN ITEM_INFO C
        ON T.ITEM_ID = C.ITEM_ID

    -> 마찬가지로 merge함수를 사용해 join결과 출력

    : PARENT 아이템의 업그레이트 아이템을 아이템 NAME으로 한눈에 알 수 있음

  1. 아이템 A의 업그레이드 아이템의 NAME은 B, C
  2. 아이템 B의 업그레이트 아이템의 NAME은 D, E
  • 이처럼 JOIN을 2개 이상 사용하는것이 가능함

[ON 조건의 기준]

  1. 한 테이블의 기본키(PK) - 다른 테이블의 외래키(FK) <- 정석!
  2. PK-FK가 아니더라도 의미적으로 같은 값을 가지면 JOIN가능
  3. 복합조건 가능 ex) ON A.YEAR = B.YEAR AND A.MONTH = B.MONTH
  4. 중복이 많은 컬럼을 기준으로 JOIN하면 X


  • SELECT C.ITEM_ID, C.ITEM_NAME, C.RARITY
    • 업그레이드 아이템의 데이터를 출력하는 것으로 P(부모 아이템)가 아닌 C(업그레이드/자식 아이템)의 컬럼을 선택
  • WHERE P.RARITY = 'RARE'
    • 아이템의 희귀도가 'RARE' 인 아이템의 업그레이드 아이템을 구하는 것이므로 P(부모 아이템)의 희귀도를 기준으로 하여 조건 설정함

profile
fun coding

0개의 댓글