article thumbnail image
Published 2022. 7. 8. 22:26

1. JPQL - 경로 표현식

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

 

 

2. 경로 표현식 용어 정리

• 상태 필드(state field): 단순히 값을 저장하기 위한 필드 (ex: m.username) 
• 연관 필드(association field): 연관관계를 위한 필드


• 단일 값 연관 필드:
@ManyToOne, @OneToOne, 대상이 엔티티(ex: m.team) 


• 컬렉션 값 연관 필드:
@OneToMany, @ManyToMany, 대상이 컬렉션(ex: m.orders)

 

 

 

2. 경로 표현식 특징

• 상태 필드(state field): 경로 탐색의 끝, 탐색X 

JPQL: select m.username, m.age from Member m 
 SQL: select m.username, m.age from Member m


• 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색O 

 JPQL: select o.member from Order o 


SQL:
select m.* 
 from Orders o 
 inner join Member m on o.member_id = m.id


• 컬렉션 값 연관 경로: 묵시적 내부 조인 발생, 탐색X 

 

명시적 조인: join 키워드 직접 사용
• select m from Member m join m.team t


묵시적 조인: 경로 표현식에 의해 묵시적으로 SQL 조인 발생(내부 조인만 가능) 
• select m.team from Member m


• FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능

 

• select o.member.team from Order o -> 성공
• select t.members from Team -> 성공
• select t.members.username from Team t -> 실패
• select m.username from Team t join t.members m -> 성공

 

 

 

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

• 항상 내부 조인
• 컬렉션은 경로 탐색의 끝, 명시적 조인을 통해 별칭을 얻어야함
• 경로 탐색은 주로 SELECT, WHERE 절에서 사용하지만 묵시적 조인으로 인해 SQL의 FROM (JOIN) 절에 영향을 줌

 

 

 

4. 실무 조언

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

 

 

 

 

출처 : 김영한, 자바 ORM 표준 JPA 프로그래밍 - 기본편

'JPA' 카테고리의 다른 글

JPQL - 다형성 쿼리  (0) 2022.07.10
JPQL - 페치 조인(fetch join)  (0) 2022.07.10
JPQL 기본 함수  (0) 2022.07.08
조건식 - CASE 식  (0) 2022.07.08
JPQL 타입 표현  (0) 2022.07.08
복사했습니다!