JPA/JPQL

[JPA] 경로 표현식

Boradoris 2023. 3. 11. 14:28

경로 표현식

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

 

 

 

경로 표현식 용어 정리

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

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

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

 

 

경로 표현식 특징

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

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

 

 

상태 필드 경로 탐색

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

 

 

단일 값 연관 경로 탐색

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

 

 

명시적 조인, 묵시적 조인

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

 

 

경로 표현식 - 예제

  • 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 -> 성공

 

 

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

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

 

 

실무

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

 


출처 : https://www.inflearn.com/course/ORM-JPA-Basic

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

[JPA] 페치 조인의 특징과 한계  (0) 2023.03.15
[JPA] 페치 조인(fetch join)  (0) 2023.03.11
[JPA] 조건식  (0) 2023.03.10
[JPA] JPQL 타입 표현과 기타식  (0) 2023.03.10
[JPA] 서브 쿼리  (0) 2023.03.10