인프런 커뮤니티 질문&답변

vnfthr님의 프로필 이미지
vnfthr

작성한 질문수

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

수업 자료

확실한 답을 못얻었습니다.

작성

·

220

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

 

 

일단 페치조인으로 둘이상의 컬렉션은 페치 조인 할 수 없다는 걸 알았습니다,

이럴땐 배치사이즈로 컬렉션들을 in 절로 끌고오면 되는것도 이해했습니다.

 

궁금한것은 in절로 끌고온 컬렉션들안에 또 @oneToMany로 선언된 엔티티가 존재한다면 그 컬렉션들은 @Batchsize옵션으로 in절로 끌고 올 수 가 없나요? 배치 사이즈를 줘도 컬조회할 기준 엔티티에 직접적으로 존재하지 않는 컬렉션 엔티티들은 in절로 끌고오지않고 n+1이 터지는것같습니다

답변 1

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. vnfthr님

도움을 드리고 싶지만 질문 내용만으로는 답변을 드리기 어렵습니다.

실제 동작하는 전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx

 

주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

 

추가로 다음 내용도 코멘트 부탁드립니다.

1. 문제 영역을 실행할 수 있는 방법

2. 문제가 어떻게 나타나는지에 대한 상세한 설명

감사합니다.

vnfthr님의 프로필 이미지
vnfthr
질문자

코드는 따로 없습니다 죄송합니다 ( 빈번하게 일어나는 상황이라서요 )

 

EntityA 1:N EntityB

EntityB 1:N EntityC

이런식으로 있을 때 ,

EntityA 가 EntityB를 @oneToMany로 가지고있고,

EntityB 가 EntityC를 @oneToMany로 가지고 있습니다.

 

배치사이즈 옵션을 넣고

select a from EntityA a 했을때 , EntityA의 갯수만큼 EntityB에 in절로 EntityA의 키값을 넣어서 @oneToMany를 한번에 끌고왔다고 했을 때 ,

EntityB안에있는 EntityC를 또 EntityB의 갯수만큼 EntityC에 in절로 EntityB의 키값을 넣어서 한번에 끌고 올 수 있는 방법이 있는지 궁금했습니다.

 

다중 페치조인 안되는걸 알지만 예를 들어서 이런걸 원한다고 생각하시면 될 것 같습니다

select a from EntityA a join fetch EnitityB(List) b join fetch b.EntityC(List)

이런식으로 컬럼 갯수가 일대다 일대다로 기하급수적으로 증가하는 경우인데

배치사이즈를 사용하여 select a from EntityA a 를 했을 땐 a.EntityB 에 접근할때 당연히 in 절로 가져와주지만 EntityB의 일대다인 EntityC 를 조회 할 땐 N+1이 다시 터집니다

엮여있는 모든 연관관계들을 IN절로 태우고 싶은데 방법이 없을까요? 

 

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. vnfthr님

다음에 답변을 달아두었습니다.

https://www.inflearn.com/questions/1005808

감사합니다.

vnfthr님의 프로필 이미지
vnfthr

작성한 질문수

질문하기