728x90
경로 표현식
.(점)을 찍어 객체 그래프를 탐색하는 것
예)
select m.username -> 상태 필드
from Member m
join m.team t -> 단일 값 연관 필드
join m.orders o -> 컬렉션 값 연관 필드
where t.name = '팀A'
용어 정리
상태 필드: 단순히 값을 저장하기 위한 필드
연관 필드: 연관관계를 위한 필드
- 단일 값 연관 필드:
- @ManyToOne, @OneToOne, 대상이 엔티티
- 컬렉션 값 연관 필드:
- @OneToMany, @ManyToMany, 대상이 컬렉션
경로 표현식 특징
- 상태 필드: 경로 탐색의 끝, 탐색 X
JPQL: select m.username, m.age from Member m
SQL: select m.username, m.age from Member m
String query = "select m.username From Member m"; //탐색 더 불가능
- 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색 O
- 단점: 쿼리 튜닝이 어렵다.
String query = "select m.team From Member m";
- 컬렉션 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색 X
- From절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능
String query = "select m From Team t join t.members m";
명시적 조인 VS 묵시적 조인
- 명시적 조인: join 키워드 직접 사용
- select m from Member m join m.team t
- 묵시적 조인: 경로 표현식에 의해 묵시적으로 SQL 조인 발생(내부 조인만 가능)
- select m.team from Member m
경로 탐색을 사용한 묵시적 조인 시 주의사항
- 항상 내부 조인
- 컬렉션은 경로 탐색의 끝, 명시적 조인을 통해 별칭을 얻어야 한다.
- 경로 탐색은 주로 SELECT, WHERE 절에서 사용하지만 묵시적 조인으로 인해 SQL의 FROM(JOIN)절에 영향을 준다.
실무에서는...
묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움이 있다.
가급적 묵시적 조인 대신에 명시적 조인을 사용하자!
조인은 SQL 튜닝에 중요 포인트다!
728x90
'💻dev > 🌱Java+Spring' 카테고리의 다른 글
JPA | JPQL 중급 문법 뿌시기 - 다형성 쿼리, 엔티티 직접 사용, Named 쿼리, 벌크 연산 (0) | 2023.05.04 |
---|---|
JPA | JPQL 중급 문법 뿌시기 - 페치 조인(fetch join) (0) | 2023.05.04 |
JPA | JPQL 문법 뿌시기 - 타입 표현, 조건식, 기본 함수 (0) | 2023.05.04 |
JPA | JPQL 문법 뿌시기 - 조인, 서브 쿼리 (0) | 2023.05.04 |
JPA | JPQL 문법 뿌시기 - 프로젝션(SELECT), 페이징 API (0) | 2023.05.03 |