Posts [자바 ORM 표준 JPA 프로그래밍-기본편] 경로표현식
Post
Cancel

[자바 ORM 표준 JPA 프로그래밍-기본편] 경로표현식

본 포스팅은 인프러의 JPA 기본편을 수강하고 정리하는 내용입니다.


경로 표현식

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

image

경로 표현식 용어 정리

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

경로 표현식 특징

  • 상태 필드(state field): 경로 탐색의 끝, 탐색X
  • 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색O
    • 편해보이지만 조심해서 써야함(쿼리 튜닝할 때 어려움)
    • 묵시적 내부 조인이 발생하게 짜면 안됨 (운영하기 너무 어려움..)
      1
      2
      
      String query = "select m.team from Member m";
      List<Team> resultList = em.createQuery(query, Team.class).getResultList();
      
  • 컬렉션 값 연관 경로: 묵시적 내부 조인 발생, 탐색X
1
2
3
4
5
6
7
String query = "select t.members from Team t";
Collection result = em.createQuery(query, Collection.class)
    .getResultList();

for (Object o : result) {
System.out.println("s = " + o);
}
  • FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능
1
2
3
4
5
String query = "select m.username from Team t join t.members m";
List<String> result = em.createQuery(query, String.class)
        .getResultList();

System.out.println("result = " + result);

Note: 실무에서 권장하는 방법은 그냥 아예 묵시적 조인을 쓰지 않는 것이다. 명시적 조인을 써야 한다. 그래야 실제 쿼리 튜닝도 쉽고 유지보수할때도 훨씬 좋다.

상태 필드 경로 탐색

  • 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:
1
2
3
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, WHERE 절에서 사용하지만 묵시적 조인으로 인해 SQL의 FROM (JOIN) 절에 영향을 줌

실무 조언

  • 가급적 묵시적 조인 대신에 명시적 조인 사용(중요)
  • 조인은 SQL 튜닝에 중요 포인트
  • 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움
This post is licensed under CC BY 4.0 by the author.

[자바 ORM 표준 JPA 프로그래밍-기본편] JPQL 함수

[자바 ORM 표준 JPA 프로그래밍-기본편] 페치조인1 - 기본