여러 테이블 fetch join 질문 드립니다!
안녕하세요!
Event와 Member의 N : N 관계를 중간 테이블(EventMEmber)을 만들어서 풀어낼때
Event <-> EventMember <-> Member에서
Event를 리스트로 조회하려고 하는데 이때 EventDto에 Member의 String name 필드를 리스트로 가져오려고 합니다.
1.
@Query("select distinct e from Event e " +
"join fetch e.eventMember a " +
"join fetch a.member")Event에 중간 엔티티인 EventMember를 fetch join하고 별칭을 사용해서 EventMember의 member를 fetch join 했습니다.
fetch join에서 별칭 사용을 권장하지 않고, 컬렉션을 fetch join을 하면 추후 페이징에 문제가 생길 것 같습니다.
2.
@Query(value =
"select e from EventMember e " +
"join fetch e.member " +
"join fetch e.event")List<EventMember> eventMembers = eventMemberRepository.findAllEventArtist();
Map<Event, List<String>> events = new HashMap<>();
for (EventMember eventMember : eventMembers) {
if (!events.containsKey(eventMember.getEvent())) {
events.put(eventMember.getEvent(), new ArrayList<>());
}
events.get(eventMember.getEvent())
.add(eventMember.getMember().getName());
}
중간 엔티티인 EventMember로 Event와 Member를 fetch join으로 가져오고 자바 코드로 원하는 응답을 만들었습니다.
혹시 둘중 더 나은 방법이나 더 좋은 방법, 제가 잘못 알고 있는 부분이 있으면 말씀 부탁드리겠습니다 ㅠㅠ
답변 1
강의 관련 외 질문입니다.
0
69
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
1
92
1
BeanCreationException
0
92
3
Update 후 UpdateMemberResponse 매핑할 때
0
50
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
101
2
페이징 + 검색조건 관련해서 질문드립니다.
0
71
1
Query Dsl Q파일 질문입니다.
0
84
1
루트 쿼리라는것은
0
60
1
메서드를 분리하는 기준
0
67
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
113
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
86
2
fetch join과 영속화와 OSIV의 관계
0
88
2
Distinct 사용 전 결과에 대한 의문
0
117
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
60
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
78
2
dto 필드 속 엔티티 여부
0
60
1
뷰템플릿 사용 시
0
79
2
Result 클래스 관련 질문
0
56
1
@PostConstruct 프록시 관련 질문드립니다
0
86
1
DTO 대신 Form 사용은 안되나요?
0
138
1
OSIV ON 상태일 때
0
98
1
fetch join VS fetch join 페이징 궁금증
0
187
2
양방향 연관관계 알아보는 법?
0
107
1
16강 17강 간단 정리 이게 맞을까요 ?
0
167
2





