inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

QueryDSL 객체 로딩 후 DTO 변환시 재 로딩 하는 현상

175

임띵동

작성한 질문수 2

0

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 쿼리가 나갑니다

이 부분은 왜 그런걸까요 ?

querydsl jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

임띵동님,

QueryDSL을 사용하여 Game 엔터티를 로드한 후 DTO로 변환할 때 추가적인 select 쿼리가 발생하는 이유는 엔터티의 컬렉션 프로퍼티(missions, rewards)의 지연 로딩(fetch = FetchType.LAZY) 때문입니다.

지연 로딩으로 설정된 컬렉션들은 실제로 접근될 때까지 데이터베이스에서 데이터가 조회되지 않습니다. 따라서 DTO로 변환하기 위해 missionsrewards 컬렉션에 접근할 때 해당 컬렉션이 지연 로딩되면서 추가적인 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 엔터티를 조회할 때 missionsrewards도 함께 조회되므로 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