inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

질문 하나 드립니다.

274

김연규

작성한 질문수 11

1

즐겁게 공부하고 있습니다.  감사합니다. 

hibernate.default_batch_fetch_size  100으로 설정한 후 쿼리 나가는 걸 보고 약간 의문이 드는데요, 

초기 Order 를 2개 가지고 오고 순서가 

1번 Order -> 1번 Order에 물려있는 1,2 번 OrderItem -> 1,2번 OrderItem에 물려있는 1,2 번 Item 

2번 Order -> 2번 Order에 물려있는 3,4번 OrderItem -> 3,4번 OrderItem에 물려있는 3,4번 Item 

인 것 같습니다. 

 

하지만 쿼리 나가는 걸 보니 

1번 Order에 물려있는 1,2번 OrderItem를 DB에서 꺼내올 때, 2번에 물려있는 3,4번 OrderItem도 같이 긁어 오더라구요?? 

Item 꺼낼 때도  1,2번 OrderItem에 물려있는 1,2번 Item 긁어 올때 3,4번도 같이 긁어오구요. 

 

JPA가 제가 2번 Order에 물려있는 3,4번 OrderItem을 긁어 올지 않올지 어떻게 판단하고, 처음에 싹다 긁어오나요??... 

만약 제가 OrderId = 2 인것을 제외하는 로직을 세웠다라고 하면 이 로직전에 JPA가 일단 다 긁어 오는 것 같은데... 

 

제 생각이 맞는지... 

맞다면 JPA가 일단 그런거 모르겠고, 초장에 다 긁어 온다음에 처리를 하나요..?? 

 

미리 감사드립니다. 

JPA spring-boot spring java

답변 1

1

김영한

안녕하세요. 김연규님

이것이 hibernate.default_batch_fetch_size의 단점입니다.

나중에 사용하지 않을 값도 미리 함께 조회를 해버리는 것이지요.

그런데 실무에서 데이터베이스에서 조회한 데이터는 보통 모두 사용하기 때문에 이런 부분이 문제가 되지는 않습니다.

감사합니다.

@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.

0

32

2

강의 관련 외 질문입니다.

0

91

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

1

113

1

BeanCreationException

0

104

3

Update 후 UpdateMemberResponse 매핑할 때

0

66

1

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

0

109

2

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

0

77

1

Query Dsl Q파일 질문입니다.

0

92

1

루트 쿼리라는것은

0

68

1

메서드를 분리하는 기준

0

76

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

123

3

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

0

97

2

fetch join과 영속화와 OSIV의 관계

0

101

2

Distinct 사용 전 결과에 대한 의문

0

124

2

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

0

65

1

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

0

82

2

dto 필드 속 엔티티 여부

0

67

1

뷰템플릿 사용 시

0

86

2

Result 클래스 관련 질문

0

59

1

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

0

91

1

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

0

142

1

OSIV ON 상태일 때

0

102

1

fetch join VS fetch join 페이징 궁금증

0

192

2

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

0

113

1