-
#JPA-20 JPQL- 경로 표현식JPA 2021. 2. 23. 17:16
[출처] 인프런 김영한 강사님 -자바 ORM 표준 JPA 프로그래밍 기본
<JPQL - 경로 표현식>
경로 표현식
• .(점)을 찍어 객체 그래프를 탐색하는 것
경로 표현식 용어 정리
• 상태 필드(state field): 단순히 값을 저장하기 위한 필드 (ex: m.username)
• 연관 필드(association field): 연관관계를 위한 필드
• 단일 값 연관 필드: @ManyToOne, @OneToOne, 대상이 엔티티(ex: m.team)
• 컬렉션 값 연관 필드: @OneToMany, @ManyToMany, 대상이 컬렉션(ex: m.orders)
경로 표현식 특징
• 상태 필드(state field): 경로 탐색의 끝, 탐색X
m.username에서 더이상갈수있는게 없기때문에 경로 탐색의 끝이고 탐색이 불가능한것
• 단일 값 연관 경로: 묵시적 내부 조인(inner join) 발생, 탐색O
JpaMain Class
String query1 = "select m.username From Member m"; //m.username에서 더이상갈수있는게 없기때문에 경로 탐색의 끝이고 탐색이 불가능한것 String query = "select m.team From Member m"; //먄약 m.team으로 가게되면 묵시적인 내부 조인이 발생하게 된다. //m.team.name -> 상태필드 List<Team> resultList = em.createQuery(query, Team.class).getResultList(); for (Team team1 : resultList) { System.out.println("team1 = " + team1); }
console
Hibernate: /* select m.team From Member m */ select team1_.id as id1_3_, team1_.name as name2_3_ from Member member0_ inner join Team team1_ on member0_.TEAM_ID=team1_.id team1 = jpql.Team@30ca0779 team1 = jpql.Team@30ca0779
묵시적인 내부조인 이 발생하게 짜면안된다. 조인은 성능에 영향을 많이준다.
작은 app에선 이렇게 쓰는데 큰쪽에서 하면 튜닝하기 힘들다.
• 컬렉션 값 연관 경로: 묵시적 내부 조인 발생, 탐색X -> 안쓰는게 좋다.
• FROM 절에서 명시적 조인을 통해 별칭을 얻으면 별칭을 통 해 탐색 가능 ->이걸로 쓰자
컬렌션이기때문에 t.members 이하에 더이상 탐색할게 없다 해봣자 size이다.
상태 필드 경로 탐색
• 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 -> 성공
->그런데 조인이 o.meber 에서한번 member.team에서 한번 두번일어남
• select t.members from Team -> 성공
-> 컬렌션이지만 여기서 끝을 냈기때문임. 컬렉션은 끝을낸다!
• select t.members.username from Team t -> 실패
-> 컬렉션은 members를 그대로 들고오거나 .size정도만 가능 컬렌셕은 끝이다.!
• select m.username from Team t join t.members m -> 성공
-> t.members해서 컬렉션을 명시적 조인을 했기대문에 m에서 다시 시도했기 때문에 성공한것.
경로 탐색을 사용한 묵시적 조인 시 주의사항
• 항상 내부 조인
• 컬렉션은 경로 탐색의 끝, 명시적 조인을 통해 별칭을 얻어야함
• 경로 탐색은 주로 SELECT, WHERE 절에서 사용하지만 묵시 적 조인으로 인해 SQL의 FROM (JOIN) 절에 영향을 줌
실무 조언
• 가급적 묵시적 조인 대신에 명시적 조인 사용
• 조인은 SQL 튜닝에 중요 포인트
• 묵시적 조인은 조인이 일어나는 상황을 한눈에 파악하기 어려움
'JPA' 카테고리의 다른 글
#JPA-22 JPQL- 다형성 쿼리, 엔티티 직접 사용, Named 쿼리 (0) 2021.02.25 #JPA-21 JPQL - 페치 조인(fetch join) (0) 2021.02.23 #JPA-19 페이징 API, JOIN, JPA 기타 (0) 2021.02.23 #JPA-18 JPQL(Java Persistence Query Language) (0) 2021.02.23 #JPA-17 JPA가 지원하는 다양한 쿼리 방법 (0) 2021.02.23