BE전문가 프로젝트

경로 표현식 본문

JPA

경로 표현식

원호보고서 2022. 11. 8. 21:51
  • .(점)을 찍어 객체 그래프를 탐색하는 것
String query = "select m.team from Member m";

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

 

 

경로 표현식 특징

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

상태필드

String query = "select m.username from Member m";

상태필드(m.username)에서 더이상 갈 수 있는 곳이 없다.

 

단일 값 연관 경로

String query = "select m.team from Member m";

m.team에서 .name 또는 .id 등 값을 얻을 수 있다. 객체에서는 .(점)을 통해 하위 객체를 찾아 올 수 있지만, SQL의 경우에는 join을 해야한다. 따라서 내부적으로 join이 발생되는데 이 것을 묵시적 내부 조인이라고 한다. 튜닝이 어렵기 때문에 묵시적 내부 조인이 발생하게 작성하면 좋지 않다(성능 문제)

컬렉션 값 연관 경로

String query = "select t.memberList from Team t";

값은 가져오지만 그 뒤에 탐색이 안된다. 따라서 사용하고 싶다면 명시적인 join을 사용하여 값을 가져와야 한다.

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

String query = "select m.username from Team t join t.memberList m ";

 

위에서 설명은 했지만 묵시적 Join은 사용하지 않는 것이 좋다. 추적이 어렵고 튜닝이 어렵기 때문이다.

 

명시적 조인 : join 키워드 직접 사용

  • select m from Member m join m.team t

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

  • select m.team from Member m

 

 

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

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

 

실무 조언

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

'JPA' 카테고리의 다른 글

페치조인의 한계  (0) 2022.11.09
JPQL - 페치 조인(fetch join)  (0) 2022.11.08
JPQL 함수  (0) 2022.11.08
조건식(Case 식 등)  (0) 2022.11.07
JPQL 타입 표현  (0) 2022.11.07
Comments