본문 바로가기

Spring Data

JPQL 중급 문법 - 경로표현식

경로 표현식

. (점)을 찍어 객체 그래프를 탐색하는 것.

 

select m.username 	-> 상태 필드
from Member m		
    join m.team t	-> 단일 값 연관 필드
    join m.orders o	-> 컬렉션 값 연관 필드
where t.name = '팀A'
  • 상태 필드 : 단순히 값을 저장힉 위한 필드
  • 연관 필드 : 연관관계를 위한 필드
    • 단일 값 연관 필드 : @ManyToOne, @OneToOne 대상이 엔티티
    • 컬력션 값 연관 필드 : @OneToMany, @ManyToMany 대상이 컬렉션

경로표현식 특징

  • 상태필드 :  경로 탐색의 끝, 탐색 x
  • 단일 값 연관 경로 : 묵시적 내부 조인(inner join) 발생, 탐색 o
  • 컬렉션 값 연관 경로 : 묵시적 내부 조인 발생, 탐색 x
    • from 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능.
// 상태 필드
select m.username from Member m

// 단일 값 
select m.team.name from Member m => 쿼리 실행 시 Team 테이블과 내부조인 발생(묵시적 내부조인).

// 컬렉션 값
select t.member from Team t
select t.member.username from Team t => 실행안됌. 탐색 x
select m.username from Team t join t.members m =>  명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능.
  • 묵시적 조인 => 쿼리 튜닝하기 어렵다.. => 직관적이지 않기 때문에 어디서 내부조인이 발생했는지 찾기 어려움.

경로 탐색을 사용한 묵시적 조인 시 주의 사항

  • 항상 내부 조인
  • 컬렉션은 경로 탐색의 끝, 명시적 조인을 통해 별칭을 얻어야함
  • 경로 탐색은 주로 select, where 절에서 사용하지만 묵시적조인으로 인해 sql 의 from (join) 절에 영향을 준다.

실무조언 

  • 가급적 묵시적 조인 대신에 명시적 조인 사용
  • 조인은 sql 튜닝에 중요 포인트
  • 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움.

 

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

JPQL 중급 문법 - 페치조인2  (0) 2021.08.09
JPQL 중급 문법 - 페치 조인1  (0) 2021.08.09
JPQL 기본 문법  (0) 2021.08.09
값 타입 #9  (0) 2021.07.26
프록시와 연관관계 관리(지연로딩, 즉시로딩) #8  (0) 2021.07.23