본문 바로가기
Spring/JPA/Hibernate

JPQL 경로 표현식

by 개복이 2021. 5. 25.

경로 표현식

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

 

 

 

 

 

 

 

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

 

경로 표현식 특징

  • 상태 필드(state field) : 경로 탐색의 끝, 탐색X
  • 단일 값 연관 경로 : 묵시적 내부 조인(inner join) 발생, 탐색O
  • 컬렉션 값 연관 경로 : 묵시적 내부 조인 발생, 탐색X
    • FROM 절에서 명시적 조인을 통해서 별칭을 얻으면 별칭을 통해 탐색 가능

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

명시적 조인, 묵시적 조인

  • 명시적 조인 : join 키워드 직접 사용
    • select m from Member m join m.team t
  • 묵시적 조인 : 경로 표현식에 의해 묵시적으로 SQL 조인 발생(내부 조인만 가능)
    • select m.team from Member m

 

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

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

 

실무 조언

  • 명시적 조인 사용
  • 조인은 SQL 튜닝에 중요 포인트
  • 묵시적 조인은 조인이 일어나는 상황을 한 눈에 파악하기 어렵다.

 

 

 

 

Reference

  • 자바 ORM 표준 JPA 프로그래밍

'Spring > JPA/Hibernate' 카테고리의 다른 글

JPQL 패치 조인2 - 한계  (0) 2021.05.27
JPQL 패치 조인1 - 기본  (0) 2021.05.26
JPQL 함수  (0) 2021.05.24
JPQL 조건식 (CASE 등)  (0) 2021.05.24
JPQL 타입 표현과 기타식  (0) 2021.05.23

댓글