자바 ORM 표준 JPA 프로그래밍(인프런)

Ch11. 객체지향 쿼리 언어2(중급 문법) - 경로 표현식

webmaster 2021. 12. 18. 11:16
728x90

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

select m.username -> 상태 필드
 from Member m
 join m.team t -> 단일 값 연관 필드
 join m.orders o -> 컬렉션 값 연관 필드
where t.name = '팀A'
  • 상태 필드(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 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통 해 탐색 가능
  • size와 같은 함수는 사용이 가능하다.

명시직 조인, 묵시적 조인

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

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

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

참고

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