• 카테고리

    질문 & 답변
  • 세부 분야

    데이터 분석

  • 해결 여부

    미해결

셀프조인에서 LEFT vs INNER JOIN 차이

22.05.20 10:04 작성 조회수 495

0

안녕하세요,

DELETE 문제 풀이에서 강사님은 INNER JOIN으로 풀이주셨는데요. INNER JOIN 대신 LEFT JOIN을 사용해도 정답이 되는 거 같네요. 원래 모든 SELF JOIN 시에는 LEFT = INNER로 생각해도 될까요?

아직 LEFT JOIN / INNER JOIN이 바로 머릿속에 그려지지 않다보니 케이스 by 케이스인지, 셀프조인 시 LEFT = INNER인지 헷갈리네요

 

감사합니다.

답변 1

답변을 작성해보세요.

0

안녕하세요, 답변 드립니다.

우선 질문 주신 내용은 경우에 따라 다르며, 이 문제에서는 INNER JOIN 으로 SELF JOIN 을 하는 것과 LEFT JOIN 으로 SELF JOIN 을 하는 것의 결과가 동일합니다. 여기에서는 person 이라는 테이블의 email 컬럼으로 SELF JOIN 을 하였는데요, joinkey로 사용되는 두 컬럼에 동일한 값이 들어있기 때문에 INNER JOIN 과 LEFT JOIN 의 차이가 없습니다.

결과가 달라지는 경우는, 들어있는 값이 다른 컬럼을 joinkey로 사용하여 SELF JOIN 을 한 경우입니다. 아래 참고 문서에서 관련 예시를 보실 수 있으며, 같은 조건으로 INNER JOIN 을 했을 때와 LEFT JOIN 을 했을 때 결과에 차이가 있는 것을 확인 하실 수 있습니다.

[MySQL TUTORIAL] MySQL Self Join

이해에 도움이 될 수 있도록 LEFT JOIN 관련 문서도 함께 전달 드립니다 :)

[MySQL TUTORIAL] MySQL LEFT JOIN