inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

주문 조회 V3.1: 엔티티를 DTO로 변환 - 페이징과 한계 돌파

Batch Size에서 두 번째 Order의 ID가 IN 쿼리에 들어가는 이유

해결된 질문

399

안재우

작성한 질문수 2

2

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
처음 OrderItem을 조회할 때 두 번째 Order의 ID(11)와 함께 IN 쿼리를 통해 조회됩니다.
 
여기서 IN 쿼리에 두 번째 Order의 ID가 들어가는 이유에 대해 생각해보았습니다.
 
 
1. 현재 Order 엔티티를 통해 OrderItem을 조회하고 있다.
 
2. batch가 설정되어 있기 떄문에 1차 캐시에 들어있는 Order들을 통해 최대 batch_size개 까지 IN 쿼리를 통해 조회한다.
 
3. 조회 대상이 된 1차 캐시에 들어있던 Order들 중에 두 번째 Order가 포함되어있었기 때문에 IN 쿼리에 두 번째 Order의 ID가 함께 들어갔다.
 
4. member와 delivery를 fetch하지 않았을 때도 위와 같은 이유로 한번에 조회되었다.
 
 
이런 과정을 거쳐서 같이 조회가 되지 않았나 생각해보았습니다.
제가 생각한 이유가 맞거나 혹시 틀린 부분이 있는지 궁금합니다.
 
감사합니다.

JPA spring-boot java spring

답변 1

0

김영한

안녕하세요. 안재우님

질문이 정확히 이해가 되지 않습니다. 

두 번째 Order의 ID라는 것이 어떤 것을 의미하는지요?

구체적인 예시와 코드, 로그를 통해서 자세히 설명부탁드립니다.

0

안재우

실전! 스프링 부트와 JPA 활용 2 - 주문 조회 V3.1: 엔티티를 DTO로 변환 - 페이징과 한계 돌파 편의 20:00초 부분에서

USER1의 OrderItem을 Lazy 로딩할 때 아래와 같이 USER2의 Order ID를 IN 쿼리에 넣어 OrderItem을 한꺼번에 조회했습니다.

select ... from order_item orderitems0_ where orderitems0_.order_id in (4, 11);

이 쿼리에 들어간 USER2의 Order ID (쿼리에선 11에 해당)을 두 번째 Order의 ID라 적었습니다.

혼란을 드려서 죄송합니다.

 

0

김영한

네 재우님 생각하신 내용이 맞습니다.

감사합니다.

0

안재우

감사합니다!

강의 관련 외 질문입니다.

0

66

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

0

89

1

BeanCreationException

0

88

3

Update 후 UpdateMemberResponse 매핑할 때

0

47

1

트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?

0

99

2

페이징 + 검색조건 관련해서 질문드립니다.

0

70

1

Query Dsl Q파일 질문입니다.

0

82

1

루트 쿼리라는것은

0

58

1

메서드를 분리하는 기준

0

63

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

110

3

연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략

0

84

2

fetch join과 영속화와 OSIV의 관계

0

86

2

Distinct 사용 전 결과에 대한 의문

0

113

2

레포지토리 계층에서의 트랜잭션에 대한 의문

0

57

1

영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.

0

78

2

dto 필드 속 엔티티 여부

0

60

1

뷰템플릿 사용 시

0

76

2

Result 클래스 관련 질문

0

56

1

@PostConstruct 프록시 관련 질문드립니다

0

86

1

DTO 대신 Form 사용은 안되나요?

0

135

1

OSIV ON 상태일 때

0

96

1

fetch join VS fetch join 페이징 궁금증

0

180

2

양방향 연관관계 알아보는 법?

0

105

1

16강 17강 간단 정리 이게 맞을까요 ?

0

165

2