<컬렉션 조회 최적화> - '엔티티를 DTO로 변환 - 페치 조인 최적화' 단원에서 궁금한 점이 있습니다.
283
작성한 질문수 1
안녕하세요 영한님 강좌 잘 보고있습니다 :)
다름이 아니라 해당 <컬렉션 조회 최적화> - '엔티티를 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개 이상의 컬렉션을 가지고 있다고 보는것이 맞을까요?
긴글 읽어주셔서 감사합니다 좋은하루되세요 :)
답변 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





