- 경로 표현식
1. .(점)을 찍어 객체 그래프를 탐색하는 것이다.
select m.username -> 상태 필드
from Member m
join m.team t -> 단일 값 연관 필드
join m.orders o -> 컬렉션 값 연관 필드
where t.name = '팀A
- 경로 표현식 용어 정리
1. 상태 필드(state field): 단순히 값을 저장하기 위한 필드
- ex) m.username
2. 연관 필드(association field): 연관관계를 위한 필드
2.1. 단일 값 연관 필드: @ManyToOne, @OneToOne, 대상이 엔티티 (ex: m.team)
2.2. 컬렉션 값 연관 필드: @OneToMany, @ManyToMany, 대상이 컬렉션 (ex: m.orders)
- 경로 표현식 특징
1. 상태 필드(state field): 경로 탐색의 끝, 탐색X
2. 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색O
3. 컬렉션 값 연관 경로: 묵시적 내부 조인 발생, 탐색X
3.1. FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통 해 탐색 가능
- 상태 필드 경로 탐색
- 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";
List<String> result = em.createQuery(query, String.class)
.getResultList();
for (String s : result) {
System.out.println("s = " + s);
}
- 단일 값 연관 경로 탐색
- JPQL: select o.member from Order o
- SQL: select m.* from Orders o inner join Member m on o.member_id = m.id
String query = "select m.team.name From Member m";
List<String> result = em.createQuery(query, String.class)
.getResultList();
for (String s : result) {
System.out.println("s = " + s);
- 내부적으로 묵시적 JOIN이 발생한다. (묵시적으로 JOIN이 발생하는 것은 좋지 않다. -> 직관적이지도 않고, 수많은 연관관계에서 수많은 JOIN이 발생할 수 있기 때문이다.)
- 명시직 조인, 묵시적 조인
1. 명시적 조인: join 키워드 직접 사용
1.1. select m from Member m join m.team t
2. 묵시적 조인: 경로 표현식에 의해 묵시적으로 SQL 조인 발생 (내부 조인만 가능)
2.1. select m.team from Member m
- 경로 탐색을 사용한 묵시적 조인 시 주의사항
1. 항상 내부 조인이 발생한다.
2. 컬렉션은 경로 탐색의 끝, 명시적 조인을 통해 별칭을 얻어야한다.
3. 경로 탐색은 주로 SELECT, WHERE 절에서 사용하지만 묵시 적 조인으로 인해 SQL의 FROM (JOIN) 절에 영향을 준다.
- 가급적 묵시적 조인 대신에 명시적 조인을 사용하는 것이 좋다.
- 조인은 SQL 튜닝에 중요한 포인트다.
- 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어렵다.
출처 : 인프런 - 우아한 형제들 기술이사 김영한의 스프링 완전 정복 (자바 ORM 표준 JPA 프로그래밍 - 기본편)
'Programming > JPA' 카테고리의 다른 글
JPA - 페치 조인 (2) (0) | 2023.07.19 |
---|---|
JPA - 페치 조인 (1) (0) | 2023.07.19 |
JPA - 기본 문법 (조건식(CASE 등등), JPQL 함수) (0) | 2023.07.18 |
JPA - 기본 문법 (조인, 서브쿼리, 타입 표현과 기타식) (0) | 2023.07.18 |
JPA - 기본 문법과 기능 (기본 문법, 프로젝션, 페이징) (0) | 2023.07.18 |