BatchSize와 OneToMany에 대해 질문드립니다.
184
작성한 질문수 7
안녕하세요. 좋은 강의 정말 잘 듣고있습니다.
컬렉션 조회 최적화 - 페이징과 한계 돌파편을 보다가 궁금한 점이 생겨서 질문드립니다.
BatchSize = 100 설정 시 다대일 관계에서는 BatchSize에 설정한 만큼 100개의 데이터를 조회하는데
일대다 관계에서는 컬렉션의 크기에 따라 조회되는 데이터 크기가 굉장히 많을 수도 있어 보입니다.
이전에 예제로 사용하셨던 Team과 Member 클래스로 예를 들면
[ ManyToOne 매핑 ]
[ 사용 시 ]
위 처럼 Member 엔티티로 다대일 관계를 갖는 team에 접근하는 경우 BatchSize에 의해 최대 100개의 팀을 조회합니다.
쿼리도 생각한대로 실행되고..
그런데 아래처럼 Team 엔티티로 일대다 관계인 members 컬렉션에 접근하면
[ OneToMany 매핑 ]
[ 사용 시 ]
이런 쿼리가 실행되더라구요. 만약 해당 팀에 소속된 회원이 10000명이라 치면 10000명이 다 조회되는건가요?
애초에 실무에선 저렇게 설계하면 안되는건지, 그런건 Member를 조회하며 페이징해서 사용해야 되는지, 아니면 다르게 튜닝하는 법이 있는지 궁금해서 질문드립니다.
( 관계를 반대로 써놨었네요. 수정했습니다. )
답변 1
@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.
0
35
2
강의 관련 외 질문입니다.
0
93
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
1
114
1
BeanCreationException
0
105
3
Update 후 UpdateMemberResponse 매핑할 때
0
68
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
117
2
페이징 + 검색조건 관련해서 질문드립니다.
0
82
1
Query Dsl Q파일 질문입니다.
0
95
1
루트 쿼리라는것은
0
69
1
메서드를 분리하는 기준
0
79
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
129
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
98
2
fetch join과 영속화와 OSIV의 관계
0
104
2
Distinct 사용 전 결과에 대한 의문
0
127
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
68
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
86
2
dto 필드 속 엔티티 여부
0
74
1
뷰템플릿 사용 시
0
91
2
Result 클래스 관련 질문
0
62
1
@PostConstruct 프록시 관련 질문드립니다
0
93
1
DTO 대신 Form 사용은 안되나요?
0
144
1
OSIV ON 상태일 때
0
103
1
fetch join VS fetch join 페이징 궁금증
0
197
2
양방향 연관관계 알아보는 법?
0
115
1





