본문 바로가기

웹 기술 쌈싸먹기/JPA

[JPA] JPQL 경로표현식

JPQL 경로표현식

 

1) 경로 표현식

  • JPA에서 경로 표현식이란 .(점)을 찍어 객체 그래프를 탐색하는 것
select m.username -> 상태 필드
  from Member m
  join m.team t -> 단일 값 연관 필드
  join m.orders o -> 컬렉션 값 연관 필드
where t.name = '팀A'

 

2) 경로 표현식 용어 정리

  • 상태 필드(state field): 단순히 값을 저장하기 위한 필드 (ex: m.username)
  • 연관 필드(association field): 연관관계를 위한 필드
    • 단일 값 연관 필드: @ManyToOne, @OneToOne, 대상이 엔티티(ex: m.team)
    • 컬렉션 값 연관 필드: @OneToMany, @ManyToMany, 대상이 컬렉션(ex: m.orders)

 

3) 경로 표현식 특징

  • 상태 필드(state field): 경로 탐색의 끝, 탐색X
  • 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색O

-> 실무에선 권장 XXX 성능 튜닝엔 영향이 크다. SQL 문법대로 짜라(명시적 내부 조인)~

  • 컬렉션 값 연관 경로: 묵시적 내부 조인 발생, 탐색X
    • FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통 해 탐색 가능

 

4) 상태 필드 경로 탐색

  • JPQL
select m.username, m.age from Member m

 

  • SQL
select m.username, m.age from Member m

 

5) 단일 값 연관 경로 탐색

  • JPQL
select o.member from Order o

 

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

 

5) 경로 표현식 - 예제

## 성공 ##
select o.member.team
from Order o

## 성공 ##
## 반환형 : Colletion##
select t.members
from Team

## 실패 ##
## t.members 까지 반환형 : Colletion 이므로 더 탐색XXX ##
## t.members.size 명령어는 조회 가능 ##
select t.members.username
from Team t

## 성공 ##
select m.username
from Team t
join t.members m -> 성공

 

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

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

 

7) 실무 조언

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

'웹 기술 쌈싸먹기 > JPA' 카테고리의 다른 글

[JPA] 다형성 쿼리  (0) 2022.02.09
[JPA] 페치 조인(fetch join)  (0) 2022.02.09
[JPA] 조인, 서브쿼리  (0) 2022.02.09
[JPA] 페이징API  (0) 2022.02.09
[JPA] 다양한 쿼리 방법  (0) 2022.02.08