-
카테고리
-
세부 분야
백엔드
-
해결 여부
미해결
Batch Size를 통한 컬렉션 조회 뒷단에 대한 질문
22.12.06 03:33 작성 조회수 214
0
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
예
[질문 내용]
실제 현업을 하다보면 굉장히 깊은 뎁스의 쿼리를 사용하기도 하는데 앞단에서 컬렉션이 존재하면 뒷단에서는 fetch join을 적용하는게 불가능할까요??
이번 강의에서도 OrderItem.Item 으로 접근할때 ManyToOne이라 fetch join 으로 가져오면 좋을듯한데 OrderItem이 컬렉션이라 1+1+1 로 총 3개의 쿼리가 나간게 쫌아쉬워서요.
여기서는 깊이가 얕아서 괜찮지만 join이 깊어지면 join 갯수만큼 쿼리가 나갈테니까요...
떠오르는건 쿼리를 2개로 분리해서 직접 in으로 조회해서 직접 각 Order에 set 해주는 방법이 있을꺼같은데 그럴려면 map도 써야하고 전체 for문이 돌아버려서 성능상 불이익이 있을꺼같네요...
질문을 요약하자면, OrderItem.item을 fetch join으로 총 1+1 2개의 쿼리가 나가도록은 못하나요?
답변을 작성해보세요.
0
김영한
지식공유자2022.12.10
안녕하세요. 이현우님
ManyToOne 관계의 fetch join은 무제한으로 가능합니다.
OneToMany는 1개만 fetch join이 가능합니다.
강의 내용 뒤쪽에서 하나의 쿼리를 복잡하게 사용해서 최적화 하는 방법도 설명해드립니다.
그 이상 최적화 하는 부분은 어렵지 않나 생각합니다.
감사합니다.
답변 1