inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

주문 조회 V3: 엔티티를 DTO로 변환 - 페치 조인 최적화

페치조인 select 필드에 의문이 있습니다.

264

Gretel

작성한 질문수 11

0

이번 강의에 나온 예시처럼 fetch join을 여러 관계에 적용한다면 한번의 select 쿼리에 모든 필드값을 가져오게 됩니다.

여기서 의문이 생긴게 만약 필요한 필드의 개수가 소수라면, 해당하는 필드만 select 하여 가져오는게 성능상 좋을지 아니면 페치 조인을 통해 한방 쿼리로 가져 오는게 성능상 좋을지 입니다.

전자의 경우 다수의 select 문이 실행되겠지만 가져오는 조회하는 필드는 적고, 후자의 경우 한번의 select 문이 실행되지만 모든 필드를 조회합니다.

이러한 경우엔 어떤 방식이 유리한가요?

페치조인으로 한방에 가져오는 메서드로 여러 방면에서 재사용하는 것이 좋은지, 각 상황에 맞는 쿼리로 다수의 메서드를 만드는게 좋은지 궁금합니다.

spring JPA java spring-boot

답변 1

2

김영한

안녕하세요. Gretel님

이 부분은 성능 테스트가 필요하지만, 일반적으로 select 문이 여러게 나가게 되면 네트워크 통신이 많아져서 성능이 느려지게 됩니다.

fetch join을 사용하지 않고, join + 필요한 필드만 찍어서 dto로 조회하는 방법도 있습니다.

감사합니다.

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

0

34

2

강의 관련 외 질문입니다.

0

91

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

1

114

1

BeanCreationException

0

105

3

Update 후 UpdateMemberResponse 매핑할 때

0

66

1

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

0

113

2

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

0

79

1

Query Dsl Q파일 질문입니다.

0

93

1

루트 쿼리라는것은

0

69

1

메서드를 분리하는 기준

0

77

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

126

3

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

0

98

2

fetch join과 영속화와 OSIV의 관계

0

104

2

Distinct 사용 전 결과에 대한 의문

0

127

2

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

0

66

1

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

0

86

2

dto 필드 속 엔티티 여부

0

71

1

뷰템플릿 사용 시

0

88

2

Result 클래스 관련 질문

0

60

1

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

0

91

1

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

0

144

1

OSIV ON 상태일 때

0

102

1

fetch join VS fetch join 페이징 궁금증

0

196

2

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

0

113

1