9분30초 findOrderDtos()관련 질문입니다.
296
작성한 질문수 1
안녕하세요 팀장님
프로그래밍 강의를 재미있게 듣기는 처음입니다. ^^
findAllWithMemberDelivery()과 달리 findOrderDtos()에서는 fetch join을 사용하면 에러가 발생합니다.
return em.createQuery(
"select new jpabook.jpashop.api.dto.OrderSimpleQueryDto(o.id, m.name, o.orderDate, o.status, d.address) " +
" from Order o" +
" join o.member m " +
" join o.delivery d ", OrderSimpleQueryDto.class
).getResultList();
<자바 ORM 표준 JPA 프로그래밍>에서는
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
일반 JOIN인 경우
SELECT m FROM Member m JOIN m.team t
다음 SQL과 같다 하셨는데
SELECT M.* FROM MEMBER M INNER JOIN TEAM T ON M.TEAM_ID=T.ID
위에서는 join만 사용했는데 어떻게 member나 delivery를 별도 query로 참조하지 않고 가져왔는지 궁금합니다.
답변하신 내용중 https://www.inflearn.com/questions/23847를 참고하면
"fetch join을 사용하는 이유는 엔티티 상태에서 엔티티 그래프를 참조하기 위해서 사용하는 것입니다. 따라서 당연히 엔티티가 아닌 DTO 상태로 조회하는 것은 불가능합니다.
이 경우 fetch join을 사용하지 마시고, 그냥 순수한 join을 사용하시면 원하는 결과를 얻을 수 있습니다"
라 하셨는데 만약 위의 jpql에 fetch가 있었다면 엔티티 상태이기 때문에 에러가 나지 않고 추후 new를 통해 DTO로 변환해야 하는 것 아닌지요?
답변 1
3
안녕하세요. ipos222님^^
fetch join은 엔티티 그래프를 한번에 같이 조회하기 위해 사용하는 기능입니다.(select 절에 엔티티를 지정해야 합니다.) 그래서 엔티티를 조회하지 않으면 실패합니다.
findOrderDtos는 select new를 통해서 엔티티가 아니라 DTO를 조회하기 때문에 fetch join을 사용할 수 없습니다.
감사합니다.
강의 관련 외 질문입니다.
0
64
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
0
85
1
BeanCreationException
0
86
3
Update 후 UpdateMemberResponse 매핑할 때
0
46
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
97
2
페이징 + 검색조건 관련해서 질문드립니다.
0
70
1
Query Dsl Q파일 질문입니다.
0
81
1
루트 쿼리라는것은
0
58
1
메서드를 분리하는 기준
0
61
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
108
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
83
2
fetch join과 영속화와 OSIV의 관계
0
83
2
Distinct 사용 전 결과에 대한 의문
0
113
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
55
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
77
2
dto 필드 속 엔티티 여부
0
58
1
뷰템플릿 사용 시
0
76
2
Result 클래스 관련 질문
0
56
1
@PostConstruct 프록시 관련 질문드립니다
0
85
1
DTO 대신 Form 사용은 안되나요?
0
133
1
OSIV ON 상태일 때
0
95
1
fetch join VS fetch join 페이징 궁금증
0
179
2
양방향 연관관계 알아보는 법?
0
104
1
16강 17강 간단 정리 이게 맞을까요 ?
0
165
2





