용어 정리
- 상태 필드 : 단순히 값을 저장하기 위한 필드
- 연관 필드 : 연관관계를 위한 필드
- 단일 값 연관 필드
- @ManyToOne, @OneToOne, 대상이 엔티티
- 컬렉션 값 연관 필드
- @OneToMany, @ManyToMany, 대상이 컬렉션
특징
- 상태 필드 : 경로 탐색의 끝, 탐색 X
- 단일 값 연관 경로 : 묵시적 내부 조인(inner join) 발생, 탐색 O
- 컬렉션 값 연관 경로 : 묵시적 내부 조인 발생, 탐색 X
- FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능
- 묵시적 조인을 사용하지 말고 명시적으로 하게끔 하자
상태 필드 경로 탐색
- 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, WHERE 절에서 사용하지만 묵시적 조인으로 인해 SQL의 FROM (JOIN) 절에 영향을 줌
실무 조언
- 가급적 묵시적 조인 대신에 명시적 조인 사용
- 조인은 SQL 튜닝에 중요 포인트
- 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움