inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

BatchSize와 OneToMany에 대해 질문드립니다.

184

InJun Choi

작성한 질문수 7

0

안녕하세요. 좋은 강의 정말 잘 듣고있습니다.

컬렉션 조회 최적화 - 페이징과 한계 돌파편을 보다가 궁금한 점이 생겨서 질문드립니다.

BatchSize = 100 설정 시 다대일 관계에서는 BatchSize에 설정한 만큼 100개의 데이터를 조회하는데

일대다 관계에서는 컬렉션의 크기에 따라 조회되는 데이터 크기가 굉장히 많을 수도 있어 보입니다.

 

이전에 예제로 사용하셨던 Team과 Member 클래스로 예를 들면

[ ManyToOne 매핑 ]

[ 사용 시 ]

위 처럼 Member 엔티티로 다대일 관계를 갖는 team에 접근하는 경우 BatchSize에 의해 최대 100개의 팀을 조회합니다.

쿼리도 생각한대로 실행되고..

그런데 아래처럼 Team 엔티티로 일대다 관계인 members 컬렉션에 접근하면

[ OneToMany 매핑 ]

[ 사용 시 ]

이런 쿼리가 실행되더라구요. 만약 해당 팀에 소속된 회원이 10000명이라 치면 10000명이 다 조회되는건가요?

애초에 실무에선 저렇게 설계하면 안되는건지, 그런건 Member를 조회하며 페이징해서 사용해야 되는지, 아니면 다르게 튜닝하는 법이 있는지 궁금해서 질문드립니다.

( 관계를 반대로 써놨었네요. 수정했습니다. )

java spring-boot JPA spring

답변 1

0

David

안녕하세요. InJun Choi님, 공식 서포터즈 David입니다.

이런 경우는 말씀하신대로 별도로 Member를 조회하고, 조회할 때 페이징 처리 해야 할 것 같습니다.

감사합니다.

@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