QueryDSL 객체 로딩 후 DTO 변환시 재 로딩 하는 현상
175
작성한 질문수 2
class Game(
..
@OneToMany(mappedBy = "gameId", cascade = [CascadeType.REMOVE], fetch = FetchType.LAZY)
var missions: List<Mission> = mutableListOf(),
@OneToMany(mappedBy = "gameId", cascade = [CascadeType.REMOVE], fetch = FetchType.LAZY)
var rewards: List<Reward> = mutableListOf(),
){게임엔터티를 queryDSL 로 모두 가져온 후
class GameListResp(
var missionTitle: String?,
var rewardList: MutableList<RewardResp>,
) {
constructor(model: Game) : this(
missionTitle = model.missions.firstOrNull()?.let { MissionType.getTitle(it) },
rewardList =if(model.rewards.isNullOrEmpty()) mutableListOf() else model.rewards!!.map { RewardResp(it) }.toMutableList(),
)
DTO 로 변환 하려고 할때
미션과 리워드가 존재하지 않으면 select 쿼리가 나갑니다
이 부분은 왜 그런걸까요 ?
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
임띵동님,
QueryDSL을 사용하여 Game 엔터티를 로드한 후 DTO로 변환할 때 추가적인 select 쿼리가 발생하는 이유는 엔터티의 컬렉션 프로퍼티(missions, rewards)의 지연 로딩(fetch = FetchType.LAZY) 때문입니다.
지연 로딩으로 설정된 컬렉션들은 실제로 접근될 때까지 데이터베이스에서 데이터가 조회되지 않습니다. 따라서 DTO로 변환하기 위해 missions와 rewards 컬렉션에 접근할 때 해당 컬렉션이 지연 로딩되면서 추가적인 select 쿼리가 발생합니다.
이를 방지하기 위해서는 엔터티 조회 시점에 미리 관련 데이터들을 함께 조회하도록 설정할 수 있습니다. QueryDSL을 사용할 경우 fetchJoin을 사용하여 관련 데이터들을 함께 가져올 수 있습니다. 아래에 예시를 첨부하였습니다:
QGame game = QGame.game;
List<Game> games = new JPAQueryFactory(entityManager)
.selectFrom(game)
.leftJoin(game.missions).fetchJoin() // missions 함께 조회
.leftJoin(game.rewards).fetchJoin() // rewards 함께 조회
.fetch();
이렇게 하면 Game 엔터티를 조회할 때 missions와 rewards도 함께 조회되므로 DTO로 변환할 때 추가적인 select 쿼리가 발생하지 않습니다.
추가적인 도움이 필요하시면 언제든 말씀해 주세요!
감사합니다.
Spring Data JPA - Query Methods - Projections - Class-based Projections (DTOs)
join에대해 질문드립니다.
0
17
1
코드 질문
0
25
1
To-Do App
0
27
1
twitterdb 연결이 안돼요
1
26
2
@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.
0
33
2
changeTeam 메서드 질문
0
35
1
테스트 관련 질문!
0
53
2
안녕하세요 질문있습니다.
0
46
2
application.properties가 적용되지 않아요
1
69
3
새 프로젝트 속 제너레이터에 SpringBoot가 없습니다.
0
54
2
설정 정보 없이 임베디드 데이터베이스 생성
0
40
1
OrderServiceTest 상문주문 테스트 시 update 쿼리 문의
0
40
1
N+1 관련해서 질문있습니다.
0
93
3
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
55
2
inheritance startegy 선택시 고려사항
0
38
1
Entity 동등성 비교
0
40
1
패키지 구분에 대해 궁금한게 있습니다
0
49
2
스프링부트 서버 에러나요
0
37
1
RepositoryTest의 패키지 위치가 domain인 이유
0
60
2
도메인 모델에서 관계와 규칙을 구분하는 방법
0
84
2
16 강의 메세지 retryCount의 의도
0
46
2
JPA Repository 질문이 있습니다!
1
58
2
페이지네이션 처리를 쿼리에서 하는 방식 질문
1
50
1
UserService, CertificationService 책임 분리 기준 질문
0
40
1





