본문 바로가기
JPA/JPQL

JPQL 경로 표현식

by 킹차니 2021. 7. 22.
김영한님의 인프런 강의와 PDF를 바탕으로 정리하였습니다.
https://www.inflearn.com/courses?s=%EA%B9%80%EC%98%81%ED%95%9C

 

경로 표현식 :

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

 

 

 

경로 표현식 용어 정리

• 상태 필드(state field):

단순히 값을 저장하기 위한 필드(ex: m.username)

 

• 연관 필드(association field):

연관관계를 위한 필드

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

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

 

 

 

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

sql

 

 

 

 

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

아래와 같이 team에 점을 찍어 탐색이 가능합니다.

 

그리고 묵시적 내부조인이 발생 합니다.

Team테이블을 join.

(참고로 묵시적 조인을 사용하지 마시고, 아래에 나오는 명시적 조인을 사용하는게 좋습니다.)

 

 

 

 

 

 

 

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

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

Team의 members는 컬렉션입니다. 여기서 더이상 members에서 member의 username, age와 같은 필드로  탐색을 할 수 없습니다.

하지만 아래처럼 명시적 조인을 하여 별칭을 얻으면 탐색이 가능합니다.

 

 

 

 

명시직 조인, 묵시적 조인

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

 

묵시적 조인: 경로 표현식에 의해 묵시적으로 SQL 조인 발생(내부 조인만 가능)

select m.team from Member m

 

 

 

경로 표현식 - 예제

select o.member.teamfrom Order o -> 성공

select t.members from Team -> 성공

select t.members.username from Team t -> 실패 (t.members까지 또는 t.members.size까지는 가능하다.)
select m.username from Team t join t.members m -> 성공

 

 

 

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

항상 내부 조인

컬렉션은 경로 탐색의 끝, 명시적 조인을 통해 별칭을 얻어야함

경로 탐색은 주로 SELECT, WHERE 절에서 사용하지만 묵시적 조인으로 인해 SQLFROM (JOIN) 절에 영향을 줌

 

 

 

 가급적 묵시적 조인 대신에 명시적 조인 사용

 조인은 SQL 튜닝에 중요 포인트
묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움

'JPA > JPQL' 카테고리의 다른 글

JPQL - 패치조인의 특징과 한계  (0) 2021.07.24
JPQL - 페치 조인(fetch join)  (0) 2021.07.23
JPQL 기본함수  (0) 2021.07.21
JPQL 조건식(CASE 등)  (0) 2021.07.21
JPQL 타입표현과 기타식  (0) 2021.07.21