inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

<컬렉션 조회 최적화> - '엔티티를 DTO로 변환 - 페치 조인 최적화' 단원에서 궁금한 점이 있습니다.

283

남대영

작성한 질문수 1

0

안녕하세요 영한님 강좌 잘 보고있습니다 :)

다름이 아니라 해당 <컬렉션 조회 최적화> - '엔티티를 DTO로 변환 - 페치 조인 최적화' 에서 궁금한점이 생겨 질문을 남기게 되었습니다.

컬렉션 조회시 해당 엔티티에서 1개이상 컬렉션을 조회하지 말라고 하셨고 이게 조인되면서 테이블이 뻥튀기 되니 우리가 원했던(기대했던) 데이터가 깨져서 조회될 수 있고 이게 DB의 한계때문에 어쩔수없다는점은 이해되었습니다.

그러면 1개 이상의 컬렉션을 가져야 하는 경우는 설계의 오류인것일까요?

 

위와같은 구조에서 A테이블은 B 와 1:N 관계이고 B 테이블은 C테이블과 1:N 관계이며 A -> B -> C 형태로 종속되어있는 구조가 있다고 예를 들어보겠습니다.

그러면 아래와 같이  쿼리를 날리게 된다면

SELECT a FROM A a

FETCH JOIN B b

FETCH JOIN b.c c 

이것도 A가 1개 이상의 컬렉션을 가지고 있다고 보는것이 맞을까요?

 

긴글 읽어주셔서 감사합니다 좋은하루되세요 :)

JPA spring-boot spring java

답변 1

-1

남대영

다음편(엔티티를 DTO로 변환 - 페이징과 한계돌파)을 보니 해결할 수 있는 방법은 ToOne 필드들은 그대로 패치조인을 시켜버리고 컬렉션 필드는 지연로딩을 그대로 두되 BatchSize를 지정해서 지연로딩을 최적화 시키는 방법이 있는걸 알았습니다.

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

0

35

2

강의 관련 외 질문입니다.

0

93

2

SpringBoot4 + Hibernate7 모듈 등록 방법 공유

1

114

1

BeanCreationException

0

105

3

Update 후 UpdateMemberResponse 매핑할 때

0

68

1

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

0

117

2

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

0

82

1

Query Dsl Q파일 질문입니다.

0

95

1

루트 쿼리라는것은

0

69

1

메서드를 분리하는 기준

0

79

1

findAllWithMemberDelivery 메서드 질문드립니다.

0

129

3

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

0

98

2

fetch join과 영속화와 OSIV의 관계

0

104

2

Distinct 사용 전 결과에 대한 의문

0

127

2

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

0

68

1

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

0

86

2

dto 필드 속 엔티티 여부

0

73

1

뷰템플릿 사용 시

0

91

2

Result 클래스 관련 질문

0

62

1

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

0

93

1

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

0

144

1

OSIV ON 상태일 때

0

103

1

fetch join VS fetch join 페이징 궁금증

0

196

2

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

0

113

1