1. 경로 표현식
: 점(.)을 찍어 객체 그래프를 탐색하는 것을 말한다
select m.username -> 상태 필드(state field): 단순히 값을 저장하기 위한 필드, 경로 탐색의 끝으로 더이상의 탐색은 불가능
from Member m
join m.team t -> 단일 값 연관 필드: 연관관계를 위한 필드로, @ManyToOne, @OneToOne, 대상이 엔티티인 필드다.
시적 내부 조인이 발생하고, 탐색 가능하다
join m.orders o -> 컬렉션 값 연관 필드: 연관관계를 위한 필드로, @OneToMany, @ManyToMany, 대상이 컬렉션인 필드다
묵시적 내부조인 발생하고, 탐색 불가능하다
from 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능하다
where t.name='팀A'
-상태 필드 경로 탐색(JPQL,SQL 동일하다)
1) JPQL: select m.username, m.age from Member m
2) SQL: select m.username, m.age from Member m
-단일 값 연관 경로 탐색
1)JPQL: select o.member from Order o
2)SQL: select m.* from Orders o inner join Member m on o.member_id=m.id(공부)
-명시적 조인/ 묵시적 조인
1) 묵시적 조인: join 키워드를 직접 사용한다.
-> select m from Member m join m.team t
2) 명시적 조인: 경로 표현식에 의해 묵시적으로 SQL 조인이 발생한다(내부조인만 가능하다)
-> select m.team from Member m
-경로 탐색을 사용한 묵시적 조인 시 주의사항
항상 내부 조인을 한다
컬렉션은 탐색의 끝이므로 명시적 조인을 통해 별칭을 얻어야 한다
경로 탐색은 주로 select,where 절에서 사용하지만 묵시적 조인으로 인해 sql의 from (join) 절에 영향을 준다
-묵시적 내부 조인이 발생하지 않게 쿼리를 짜야한다. 중요!!
//회원1, 팀1(SQL 가져옴)
//회원2, 팀1(1차 캐시에서 가져옴)
//회원3, 팀2(SQL로 가져옴)
===> 가급적 묵시적 조인 대신에 명시적 조인을 사용한다.
조인은 SQL 튜닝에 중요 포인트이다
묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어렵다
'JPA' 카테고리의 다른 글
[JPA] OSIV에 대해서 (0) | 2022.03.19 |
---|---|
[JPA] 2/24 공부내용 정리(페치 조인(main),다형성 쿼리,엔티티 직접 사용, Named 쿼리, 벌크연산) (0) | 2022.02.26 |
[JPA] 2/24 공부내용 기록(조인,on 절, 서브쿼리) (0) | 2022.02.26 |
[JPA] 2/22 공부 내용 기록(값타입,Embedded Type) (0) | 2022.02.25 |
[JPA] 2/22 공부내용 기록(지연 로딩, cascade, 고아객체) (0) | 2022.02.25 |