본문 바로가기
Study/JPA

객체지향 쿼리 언어) JPQL - 경로 표현식

by _비니_ 2024. 7. 30.

📌 JPQL - 경로 표현식

 

📌 경로 표현식

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

 

상태필드, 단일 값 연관필드, 컬렉션 값 연관 필드

어디로 가느냐에 따라 결과 값이 달라짐.

⇒ 3가지를 구분해 이해해야 함.!!

  • 상태 필드(state field): 단순히 값을 저장하기 위한 필드 (ex: m.username)
  • 연관 필드(association field): 연관관계를 위한 필드
    • 단일 값 연관 필드: @ManyToOne, @OneToOne, 대상이 엔티티(ex: m.team)
    • 컬렉션 값 연관 필드: @OneToMany, @ManyToMany, 대상이 컬렉션(ex: m.orders)
  • 경로 탐색은 필드의 종류에 따라 다르게 이루어짐
  • 연관 필드에서 단일 값인지 컬렉션 값인지에 따라 탐색/조인 방식이 달라짐

 

📌 경로 표현식 특징

  • 상태 필드(state field): 경로 탐색의 의미하며, 더 이상의 탐색이 불가능
String query = "select m.username From Member m";

>> username 에서 또 .(점)을 찍어 어디를 탐색해갈 수 없다는 의미

 

  • 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 추가로 탐색O

  • member와 team을 묵시적으로 join ⇒ team을 select
  • 되도록이면 묵시적 내부 조인이 발생하지 않도록 쿼리 짜기

 

  • 컬렉션 값 연관 경로: 묵시적 내부 조인 발생, 추가 탐색이 불가.
    • FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능
String query = "select m.username From Team t join t.members m";

>> 조인으로 별칭 m을 얻어 m.username으로 탐색 가능

 

 

📌 상태 필드 경로 탐색

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

⇒ JPQL 이 SQL로 그대로 내려간다?

 

 

📌 단일 값 연관 경로 탐색

  • 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

 

// 조인이 2번 실행
• select o.member.team 
from Order o -> 성공 

// 컬렉션. 추가 탐색은 불가
• select t.members from Team -> 성공 

// 컬렉션에서는 추가 탐색 불가하므로. size정도만 가능
• select t.members.username from Team t -> 실패

// 컬렉션을 명시적 조인으로 가져왔으므로 성공
• select m.username from Team t join t.members m -> 성공

 

 

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

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

 

 

🚨 실무 조언 🚨

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

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

객체지향 쿼리 언어) Named 쿼리, 벌크 연산  (0) 2024.07.30
객체지향 쿼리 언어) JPQL - 페치 조인(fetch join)  (0) 2024.07.30
JPQL  (0) 2024.07.27
조인과 서브쿼리  (0) 2024.07.27
프로젝션과 페이징  (0) 2024.07.27