N번 페이지 M개 조회에서 Left Join에 대한 궁금증
학습 관련 질문을 최대한 상세히 남겨주세요!
고민 과정도 같이 나열해주셔도 좋습니다.
먼저 유사한 질문이 있었는지 검색해보세요.
인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
페이지네이션에서 N번 페이지 M개의 댓글 조회에서
Left Join을 쓰는 이유가 궁금합니다.
Article, Comment를 하면서 inner join을 해도 되지 않을까 생각을 했습니다. 당연히 PK이기 때문에 null 이 없어LEFT JOIN이나 INNER JOIN이나 제 생각엔 성능 차이가 없을 거라고 생각은 해서 Query Plan으로 확인해 보니 똑같더라고요.
하지만 제가 모르는 부분들이 있어서 그런건 아닐까 생각을 해서 질문드립니다.
조금 찾아보니까 Inner Join은 양쪽 인덱스 활용이 가능해 옵티마이저가 최적의 조인 순서를 선택하고, Left Join은 왼쪽 -> 오른쪽 고정이니까 옵티마이저에게 맡기기 보다는 확실하게 하려는 것 때문인가 하는 생각도 들었습니다. 답변 주시면 감사하겠습니다 ㅎㅎ
답변 2
0
이신광님, 안녕하세요!
어차피 서브 쿼리도 article 테이블에서 article_id를 가져오므로,
말씀하신대로 left join과 inner join 둘 중 뭘로 하든 차이는 없습니다.
특별한 이유는 없고 동작만 이해할 수 있다면 편하신 방향으로 만드셔도 됩니다!
0
안녕하세요, 인프런 AI 인턴입니다. 이신광님.
페이지네이션 및 조인 전략에서 LEFT JOIN과 INNER JOIN에 대해 궁금증을 가지고 계신 점 이해합니다. 두 가지 주요 조인 방식의 차이와 그 사용 이유에 대해 정리해드리겠습니다.
INNER JOIN과 LEFT JOIN의 차이점
INNER JOIN:
- 두 테이블 간의 공통적인 데이터만 가져옵니다.
- 각 테이블에 매칭되는 데이터가 존재해야만 결과에 포함됩니다.
- 두 테이블 간의 공통적인 데이터만 가져옵니다.
LEFT JOIN:
- 좌측 테이블의 모든 데이터를 가져오며, 우측 테이블에 매칭되는 값이 없더라도 좌측 테이블의데이터는 무조건 포함됩니다.
- 매칭되지 않는 경우, 우측 테이블의 값은
NULL로 표시됩니다.
- 좌측 테이블의 모든 데이터를 가져오며, 우측 테이블에 매칭되는 값이 없더라도 좌측 테이블의데이터는 무조건 포함됩니다.
성능 및 최적화
- 일반적으로
INNER JOIN은 매칭되는 부분에 한해서만 데이터를 처리하므로,LEFT JOIN보다 조금 더 작은 데이터를 반환하는 특성을 가집니다. 그러나 단순한 쿼리에서는 성능 차이가 거의 없는 경우도 많습니다.
- 옵티마이저는
INNER JOIN과LEFT JOIN의 수행 순서를 다르게 처리할 수 있습니다. 특히, 인덱스 활용이 중요한 경우 옵티마이저는INNER JOIN를 통해 더 나은 최적화를 할 수 있습니다.
사용 시 고려할 점
- 만약 두 테이블 간의 매칭이 항상 존재한다는 확신이 있고,
NULL처리이 불필요하다면INNER JOIN이 더 직관적이고 최적화된 선택일 수 있습니다.
- 반면, 만약 데이터를 최대한 포괄적으로 유지하면서 누락을 방지하고 싶다면
LEFT JOIN을 사용할 수 있습니다.
질문 주신 상황에서, LEFT JOIN을 사용한 이유가 정말 두 테이블 간의 모든 관계를 철저히 보장하기 위해서일 수도 있으며, 이는 데이터의 완전성을 확인하기 위한 방안일 수 있습니다.
유사한 질문과 관련된 기존 답변을 아래 링크에서 확인할 수 있습니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
consumer에서 에러가 발생할 경우 데이터 유실 문의
0
35
2
게시글 테스트 데이터 삽입
0
43
2
정렬, 필터, 검색 등의 조건이 붙을 경우 최적화할 수 있는 방법이 무엇이 있을까요?
0
92
2
좋아요 기능 정합성 보장 방법
0
89
2
좋아요 동시성처리 최적의 선택?
1
112
2
프론트엔드 msa 환경 api 주소 통합? 과 서버끼리 통신 방식에대해
0
83
2
안녕하세요 무한스크롤 강의듣다가 질문이 있습니다.
0
53
1
조회수 조회 로직 질문
1
64
2
비로그인 유저도 어뷰징 방지 정책
1
62
2
CommentServiceTest의 테스트 로직 질문
0
49
2
무한 스크롤 방식에서 페이지 번호 방식 쿼리의 문제점 의문
1
69
2
path 쿼리 관련 질문드립니다!
0
54
2
antigravity 에디터를 쓰신다면 종료해주세요
1
119
0
프로젝트 구조
0
80
2
article_like_count api test
0
69
2
이벤트 페이로드 객체의 생성 방식이 팩토리 메서드 패턴이 아닌 빌더 패턴인 이유가 궁금합니다!.
0
100
2
[33. 좋아요 수 구현] 에서 테스트 하는 화면 동시성 문제
0
86
2
findByPath에서 articleId로도 검색을 해야 할 것 같아요.
0
86
3
jpa ddl-auto none을 하는 이유와 join 방법
0
91
2
팩터리 메소드와 response 객체 사용 이유가 궁금합니다!
0
84
2
커서 기반 페이지네이션 과 무한 스크롤링
0
95
2
게시글 생성 로직에서 오류 발생시 redis 게시글 수 되돌리기
0
94
2
멀티 모듈이 아닌 MSA 환경에서 common
0
145
2
2Depth 강의 도중 궁금한 점 있어요!!
0
72
2





