250x250
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 |
Tags
- 김영한
- 추상클래스
- 테스트코드
- http 메시지 컨버터
- 코드트리조별과제
- 티스토리챌린지
- 참조변수
- 오블완
- 예외와 트랜잭션 커밋
- 오버라이딩
- 코딩테스트
- 백준
- 인터페이스
- 스프링컨테이너
- fielderror
- java
- equals()
- 프록시
- 싱글톤
- 프로그래머스
- DI
- html form
- 스프링
- @configuration
- 의존관계
- objecterror
- HttpServletResponse
- 코드트리
- 서블릿
- 다익스트라
Archives
- Today
- Total
minOS
객체지향 쿼리 언어 - 경로 표현식 본문
728x90
경로 표현식
- .(점)을 찍어 객체 그래프를 탐색하는 것
select m.username -> 상태 필드 from Member m join m.team t -> 단일 값 연관 필드 join m.orders o -> 컬렉션 값 연관 필드 where t.name = '팀A'
경로 표현식 용어 정리
- 상태 필드(state field): 단순히 값을 저장하기 위한 필드 (ex: m.username)
- 연관 필드(association field): 연관관계를 위한 필드
1) 단일 값 연관 필드: @ManyToOne, @OneToOne, 대상이 엔티티(ex: m.team)
2) 컬렉션 값 연관 필드: @OneToMany, @ManyToMany, 대상이 컬렉션(ex: m.orders)
경로 표현식 특징
- 상태 필드(state field): 경로 탐색의 끝, 탐색X
ex) JPQL: select m.username, m.age from Member m
SQL: select m.username, m.age from Member m
- 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색O
ex) JPQL: select o.member from Order o
SQL:select m.* from Orders o inner join Member m on o.member_id = m.id
- 컬렉션 값 연관 경로: 묵시적 내부 조인 발생, 탐색X
• FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통해 탐색 가능
select m.username from Team t join t.members m
명시적 조인, 묵시적 조인
- 명시적 조인: join 키워드 직접 사용
select m from Member m join m.team t
- 묵시적 조인: 경로 표현식에 의해 묵시적으로 SQL 조인 발생 (내부 조인만 가능)
select m.team from Member m
경로 탐색을 사용한 묵시적 조인 시 주의사항
- 항상 내부 조인
- 컬렉션은 경로 탐색의 끝, 명시적 조인을 통해 별칭을 얻어야함
- 경로 탐색은 주로 SELECT, WHERE 절에서 사용하지만 묵시적 조인으로 인해 SQL의 FROM (JOIN) 절에 영향을 줌
실무 조언
- 가급적 묵시적 조인 대신에 명시적 조인 사용
- 조인은 SQL 튜닝에 중요 포인트
- 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움
728x90
'TIL > 김영한의 자바 ORM 표준 JPA 프로그래밍 - 기본편' 카테고리의 다른 글
객체지향 쿼리 언어 - 벌크 연산 (1) | 2025.07.10 |
---|---|
객체지향 쿼리 언어 - 페치 조인 (0) | 2025.07.10 |