본문 바로가기

Spring Data

JPQL 중급 문법 - 페치조인2

페치 조인의 특징과 한계

  • 페치 조인 대상에는 별칭을 줄 수 없다.
    • 하이버네이트는 가능, 가급적 사용 X
// 페치 조인 대상에는 별칭을 줄 수 없다.
select t from Team t join fetch t.members m

// 이렇게 풀면 안됌..
select t 
from Team t join fetch t.members m 
where m.age > 10

 

  • 둘 이상의 컬렉션은 페치 조인할 수 없다. 
  • 컬렉션을 페치 조인하면 페이징 API를 사용할 수 없다.
    • 일대일, 다대일 같은 단일 값 연관 필드들은 페치 조인해도 페이징 가능
    • 하이버네이트는 경고 로그를 남기고 메모리에서 페이징(매우 위험)

컬렉션을 페치조인하면 데이터가 늘어남.

정리

  • 모든 것을 페치 조인으로 해결할 수는 없음
  • 페치 조인은 객체 그래프를 유지할 때 사용하면 효과적
  • 여러 테이블을 조인해서 엔티티가 가진 모양이 아님 전혀 다른 결과를 내야 하면, 페치 조인보다는 일반 조인을 사용하고 필요한 데이터들만 조회해서 DTO로 반환하는 것이 효과적이다.

'Spring Data' 카테고리의 다른 글

벌크 연산  (0) 2021.08.09
JPQL 중급 문법 - 페치 조인1  (0) 2021.08.09
JPQL 중급 문법 - 경로표현식  (0) 2021.08.09
JPQL 기본 문법  (0) 2021.08.09
값 타입 #9  (0) 2021.07.26