오봉이와 함께하는 개발 블로그
JPA - 경로 표현식 본문
728x90
경로 표현식
경로 표현식이란 .(점)을 찍어서 객체 그래프를 탐색하는 것이다.
select m.username -> 상태 필드
from Member m
join m.tean t -> 단일 값 연관 필드
join m.orders o -> 컬렉션 값 연관 필드
where t.name
용어 정리
- 상태 필드(state field) : 단순히 값을 저장하기 위한 필드
- 연관 필드(assocation field) : 연관관계를 위한 필드
- 단일 값 연관 필드
- @ManyToOne, @OneToOne, 대상이 엔티티
- 컬렉션 값 연관 필드
- @OneToMany, @ManyToMany, 대상이 컬렉션
- 단일 값 연관 필드
특징
- 상태 필드(state field)
- 경로 탐색의 끝이기 때문에 더 이상 탐색이 진행되지 않는다.
- 단일 값 연관 경로
- 묵시적 내부 조인(inner join)이 발생하고 탐색을 더 할 수 있다.
- Select m.team.@@@ From Member m
- m.team이후에 .@@@이 더 가능함.
- Select m.team.@@@ From Member m
- 객체와 테이블은 다르기 때문에 쿼리문이 날아갈 때 join을 통해서 조회함.
- 편리해 보이지만 묵시적 내부 조인을 허용하면 성능상 불이익이 있기 때문에 안 된다.
- 묵시적 내부 조인(inner join)이 발생하고 탐색을 더 할 수 있다.
- 컬렉션 값 연관 경로
- 묵시적 내부 조인(inner join)이 발생하고 탐색을 더 할 수 없다.
- Select t.members From Team t
- t.members 이후에 탐색 불가능.
- Select t.members From Team t
- FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색할 수 있다.
- Select m.username From Team t join t.members m
- 묵시적 내부 조인(inner join)이 발생하고 탐색을 더 할 수 없다.
실무에서는 묵시적 조인을 사용하지 말자.
쿼리튜닝이 어렵고 운영에 어려움을 초래할 수 있다.
상태 필드 경로 탐색
- JPQL: select m.username, m.age from Member m
- SQL: select m.username, m.age from Member m
단일 값 연관 경로 탐색
- 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
예시
Select o.member.team From Order o
-> 되지만 join이 두 번 발생(o.member.team)
Select t.members From Team t
-> 컬렉션에서 멈췄기 때문에 성공
Select t.members.username From Team t
-> 컬렉션에서 한 번 더 들어갔기 때문에 실패
Select m.username From Team t Join t.members m
-> 명시적 조인을 통해 별칭을 만들고 조회했기 때문에 성공
경로 탐색을 사용한 묵시적 조인 시 주의사항
- 항상 내부 조인이다.
- 컬렉션은 경로 탐색의 끝이기 때문에 명시적 조인을 통해 별칭을 얻어서 경로를 더 찾아갈 수 있다.
- 경로 탐색은 주로 SELECT, WHERE 절에서 사용하지만 묵시적 조인으로 인해 SQL의 FROM(JOIN)절에 영향을 준다.
실무 조언
- 가급적 묵시적 조인 대신, 명시적 조인을 사용하자.
- 조인은 SQL 튜닝에 중요하기 때문이다
- 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어렵다!
출처 : 인프런 김영한 지식공유자님의 스프링 부트와 JPA 실무 완전 정복 로드맵 강의
728x90
'BE > JPA' 카테고리의 다른 글
JPA - 페치 조인 한계 (0) | 2022.07.05 |
---|---|
JPA - 페치 조인 기본 (0) | 2022.07.04 |
JPA - JPQL 함수 (0) | 2022.06.30 |
JPA - JPQL 타입 표현과 기타식, 조건식 (0) | 2022.06.30 |
JPA - 조인, 서브 쿼리 (0) | 2022.06.30 |
Comments