Notice
Recent Posts
Recent Comments
Link
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
Archives
Today
Total
관리 메뉴

개발자되기 프로젝트

경로 표현식 본문

인프런/[인프런] 자바ORM 표준 JPA 프로그래밍

경로 표현식

Seung__ 2021. 8. 16. 17:40

1.경로 표현식이란?


  • .(점)을 찍어서 객체 그래프를 탐색하는 것.
  • select m.username -> 상태 필드
     from Member m 
     join m.team t -> 단일 값 연관 필드
     join m.orders o -> 컬렉션 값 연관 필드
    where t.name = '팀A'

 

 

 

2. 용어 정리


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

 

 

 

3. 경로 표현식 특징


  • 상태 필드 : 경로 탑색의 끝임, 더 이상 탐색이 안됨.
    • username에서 더 갈데가 없음 ㅋㅋㅋ
    • "select m.username From Member m ";
    • JPQL : select m.username, m.age from Member m
    • SQL : select m.username, m.age from Member m
  • 단일 값 연관 경로 : 묵시적 내부 조인(inner) 발생, 추가 탐색 가능
    • String query = "select m.team From Member m ";
    • 조심해서 써야 한다.... jpql은 select m.team을 실행했지만
    • SQL을 보면  member로 부터 team으로 inner join이 발생한다.
    • 큰 애플리케이션의 경우 쓰면 관리 어려움.. ㅜ
    • Hibernate: 
          /* select
              m.team 
          From
              Member m  */ select
                  team1_.TEAM_ID as team_id1_3_,
                  team1_.name as name2_3_ 
              from
                  Member member0_ 
              inner join
                  Team team1_ 
                      on member0_.TEAM_ID=team1_.TEAM_ID
    • JPQL : select o.member From ORder o
    • SQL : --> 묵시적 조인 발생.
        select m.*
          from ORders o
          inner join Member m on o.member_id = m.id
  • 컬렉션 값 연관 경로 : 묵시적 내부 조인 발생, 더 이상 탐색 불가.
    • 뭐에 대해 탐색할지를 모르자너.. 
    • 하지만 from 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색이 가능함.

 

 

4. 정리


  • 묵시적 join 쓰지 말고, 명시적 join을 쓰자!

 

 

 

5. 명시적 조인, 묵시적 조인


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

 

 

6. 예제


  • 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 -> 성공 --> from을 통해 collection에서 가져오면 탐색 가능.

 

 

 

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


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

 

 

8. 실무에서는?


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

'인프런 > [인프런] 자바ORM 표준 JPA 프로그래밍' 카테고리의 다른 글

Fetch Join2  (0) 2021.08.16
FETCH JOIN  (0) 2021.08.16
JPQL 기본 함수  (0) 2021.08.16
JPQL 조건식 - CASE  (0) 2021.08.16
JPQL 타입 표현  (0) 2021.08.16
Comments