[자바 ORM 표준 JPA 프로그래밍 - 기본편] 섹션 11. 객체지향 쿼리 언어2 - 중급 문법

jada·2024년 5월 21일
0

Spring 스터디

목록 보기
29/35

JPQL - 경로 표현식


• .(점)을 찍어 객체 그래프를 탐색하는 것

  • 경로 표현식 용어 정리
    • 상태 필드(state field): 단순히 값을 저장하기 위한 필드(ex: m.username)

    • 연관 필드(association field): 연관관계를 위한 필드

    • 단일 값 연관 필드: @ManyToOne, @OneToOne, 대상이 엔티티(ex: m.team)

    • 컬렉션 값 연관 필드: @OneToMany, @ManyToMany, 대상이 컬렉션(ex: m.orders)

  • 경로 표현식 특징
    • 상태 필드(state field): 경로 탐색의 끝, 탐색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

실무 조언
• 가급적 묵시적 조인 대신에 명시적 조인 사용
• 조인은 SQL 튜닝에 중요 포인트
• 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움


JPQL - 페치 조인(fetch join)


페치 조인(fetch join)
• SQL 조인 종류X
• JPQL에서 성능 최적화를 위해 제공하는 기능
• 연관된 엔티티나 컬렉션을 SQL 한 번에 함께 조회하는 기능
• join fetch 명령어 사용
• 페치 조인 ::= [ LEFT [OUTER] | INNER ] JOIN FETCH 조인경로

엔티티 페치 조인
• 회원을 조회하면서 연관된 팀도 함께 조회(SQL 한 번에)
• SQL을 보면 회원 뿐만 아니라 팀(T.*)도 함께 SELECT

[JPQL]
select m from Member m join fetch m.team

[SQL]
SELECT M., T. FROM MEMBER M
INNER JOIN TEAM T ON M.TEAM_ID=T.ID

profile
꾸준히 발전하는 개발자가 되자 !

0개의 댓글

관련 채용 정보