Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- SpringBoot
- jpa
- JPQL
- Android
- Thymeleaf
- Spring Boot
- 스프링 핵심 원리
- 김영한
- 스프링 핵심 기능
- 인프런
- http
- 알고리즘
- Servlet
- Proxy
- 백준
- db
- JDBC
- AOP
- 스프링
- QueryDSL
- 자바
- Greedy
- kotlin
- java
- pointcut
- transaction
- 그리디
- spring
- springdatajpa
- Exception
Archives
- Today
- Total
개발자되기 프로젝트
경로 표현식 본문
1.경로 표현식이란?
.(점)을 찍어서 객체 그래프를 탐색하는 것.-
select m.username -> 상태 필드 from Member m join m.team t -> 단일 값 연관 필드 join m.orders o -> 컬렉션 값 연관 필드 where t.name = '팀A'
2. 용어 정리
- 상태 필드(state field) : 단순히 값을 저장하기 위한 필드 : m.username
- 연관 필드(association field) : 연관관계를 위한 필드
- 단일 값 연관 필드
- @ManyToOne, @OneToOne, 대상이 엔티티(m.team)
- 컬렉션 값 연관 필드
- @OneToMany, @ManyToMany, 대상이 컬렉션(m.orders)
- 단일 값 연관 필드
3. 경로 표현식 특징
- 상태 필드 : 경로 탑색의 끝임, 더 이상 탐색이 안됨.
- username에서 더 갈데가 없음 ㅋㅋㅋ
-
"select m.username From Member m ";
- JPQL : select m.username, m.age from Member m
- SQL : select m.username, m.age from Member m
- 단일 값 연관 경로 : 묵시적 내부 조인(inner) 발생, 추가 탐색 가능
-
String query = "select m.team From Member m ";
- 조심해서 써야 한다.... jpql은 select m.team을 실행했지만
- SQL을 보면 member로 부터 team으로 inner join이 발생한다.
- 큰 애플리케이션의 경우 쓰면 관리 어려움.. ㅜ
-
Hibernate: /* select m.team From Member m */ select team1_.TEAM_ID as team_id1_3_, team1_.name as name2_3_ from Member member0_ inner join Team team1_ on member0_.TEAM_ID=team1_.TEAM_ID
- JPQL : select o.member From ORder o
- SQL : --> 묵시적 조인 발생.
select m.*
from ORders o
inner join Member m on o.member_id = m.id
-
- 컬렉션 값 연관 경로 : 묵시적 내부 조인 발생, 더 이상 탐색 불가.
- 뭐에 대해 탐색할지를 모르자너..
- 하지만 from 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색이 가능함.
4. 정리
- 묵시적 join 쓰지 말고, 명시적 join을 쓰자!
5. 명시적 조인, 묵시적 조인
- 명시적 조인 : join 키워드 직접 사용
- select m from Member m join m.team t
- 묵시적 조인 : 경로 표현식에 의해 묵시적으로 SQL 조인 발생(내부 조인만 가능)
- select m.team from Member m
6. 예제
select o.member.team from Order o -> 성공- select t.members from Team -> 성공
- select t.members.username from Team t -> 실패
- select m.username from Team t join t.members m -> 성공 --> from을 통해 collection에서 가져오면 탐색 가능.
7. 경로 탐색을 사용한 묵시적 조인 시 주의사항
- 항~~~상 내부 조인
- 컬렉션은 경로 탐색의 끝! 따라서 명식적 조인을 통해 별칭을 얻어야 계속 탐색이 가능.
- 경로 탐색은 주로 SELECT, WHERE 절에서만 사용하지만,
- 묵시적 조인으로 인해 SQL의 FROM(JOIN)절에 영향을 줌.
8. 실무에서는?
- 가급적 명시적 조인을 사용하자. 최대한 묵시적 조인 사용하지 말자.
- 조인은 SQL 튜닝에 중요한 포인트임
- 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움.
'인프런 > [인프런] 자바ORM 표준 JPA 프로그래밍' 카테고리의 다른 글
Fetch Join2 (0) | 2021.08.16 |
---|---|
FETCH JOIN (0) | 2021.08.16 |
JPQL 기본 함수 (0) | 2021.08.16 |
JPQL 조건식 - CASE (0) | 2021.08.16 |
JPQL 타입 표현 (0) | 2021.08.16 |
Comments