inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! Querydsl

동적 쿼리와 성능 최적화 조회 - Where절 파라미터 사용

수업 예제에서 fetch join을 하지 않아도 team.name을 가져오는 이유

430

김동민

작성한 질문수 19

0

안녕하세요.

제가 이해한 바로는, join과 fetch join의 차이가 select하는 범위의 차이라고 알고 있습니다.

예를 들어,

Member findMember = queryFactory
                .selectFrom(member)
                .join(member.team, team)
                .where(member.username.eq("member1"))
                .fetchOne();

위 코드는 일반 join으로 team 연관관계를 조회합니다.
그 결과 member 정보만 select 합니다.

select
    m1_0.member_id,
    m1_0.age,
    m1_0.team_id,
    m1_0.username 
from
    member m1_0 
join
    team t1_0 
        on t1_0.team_id=m1_0.team_id 
where
    m1_0.username=?

 

반대로 fetch join을 하면 한 번의 쿼리로 team 정보도 select문에 포함시킵니다.

Member findMember = queryFactory 
                .selectFrom(member) 
                .join(member.team, team).fetchJoin() 
                .where(member.username.eq("member1")) 
                .fetchOne();
select
    m1_0.member_id,
    m1_0.age,
    t1_0.team_id,
    t1_0.name,  //팀 이름이 추가!
    m1_0.username 
from
    member m1_0 
join
    team t1_0 
    on t1_0.team_id=m1_0.team_id 
where
    m1_0.username=?

 

여기까지 제가 이해한 게 맞다면, 질문 드립니다.

강사님께서 Querydsl에서 where절 파라미터 사용하는 예제를 보여주실 때, 분명 코드는 leftJoin(), 즉 일반 join()을 사용하셨습니다.

public List<MemberTeamDto> searchByWhere(MemberSearchCondition condition) {
        return queryFactory
                .select(new QMemberTeamDto         (
                member.id.as("memberId"),
                member.username,
                member.age,
                team.id.as("teamId"),
                team.name.as("teamName")
            ))
                .from(member)
                .leftJoin(member.team, team)
                .where(
                       usernameEq(condition.getUsername()),
                        teamnameEq(condition.getTeamName()),
                        ageGoe(condition.getAgeGoe()),
                        ageLoe(condition.getAgeLoe()))
                .fetch();
    }

fetch join을 사용하지 않았으니 member와 연관관계를 가진 team은 프록시 객체를 가질 것입니다. 하지만 쿼리문을 보면 마치 fetch join을 한 것처럼 select 문에 team.name을 조회하는 쿼리문이 포함되어 있습니다.

/* select
        member1.id as memberId,
        member1.username,
        member1.age,
        team.id as teamId,
        team.name as teamName 
    from
        Member member1   
    left join
        member1.team as team 
    where
        team.name = ?1 
        and member1.age >= ?2 */ select
            m1_0.member_id,
            m1_0.username,
            m1_0.age,
            t1_0.team_id,
            t1_0.name 
        from
            member m1_0 
        left join
            team t1_0 
                on t1_0.team_id=m1_0.team_id 
        where
            t1_0.name=? 
            and m1_0.age>=?

 

어째서 fetch join을 하지 않았는데 한 번의 쿼리문으로 member와 team 정보를 모두 조회할 수 있는지 궁금합니다.

만약 일반 join으로 가능하다면 굳이 fetch join을 사용할 이유가 없을텐데 말입니다.

 

감사합니다!

java jpa

답변 1

0

김영한

안녕하세요. 김동민님

JPA에서 데이터를 조회하는 방법은 2가지가 있습니다.

  1. 엔티티로 조회하기

  2. DTO로 조회하기

페치 조인은 엔티티로 조회할 때만 사용할 수 있습니다.

DTO로 조회할 때는 일반 조인을 사용해야 하고, DTO는 특정 엔티티에 종속적이지 않기 때문에 여러 테이블을 조인하고, 각 테이블에 있는 원하는 값만 별도로 조회할 수 있습니다.

감사합니다.

SpringBoot 4.X에서의 Querydsl 설정

0

88

2

querydsl 오픈소스에 대한 질문

0

72

1

예제에서의 카운트 쿼리에서 join문과 where문은 필요없지 않나요?

0

109

1

Querydsl 6.X버전에 대해서 어떻게 생각하시나요?

0

317

2

여러 테이블 조인하여 통계치를 구하고자 할 때 어떤 방법이 더 효율적일까요

1

70

1

fetchResults()는 더이상 권장되지 않는다는데 맞나요?

0

160

1

querydsl sum() 메서드 없어요.

0

159

2

build 디렉터리 생성

0

136

2

자바 ORM 표준 JPA 프로그래밍 - 기본편 듣고 바로 학습해도 괜찮을까요?

0

114

2

현재 Querydsl에서 from절 서브쿼리를 지원하나요?

0

91

1

오타 제보 드립니다.

0

72

2

벌크 연산과 flush, clear

0

76

1

Run As Intellij 로 변경시 Q타입 import 불가

0

88

1

QHello import하기 문제 발생

0

147

2

등록된 함수 보는법(H2Dialect) 질문

0

68

2

5.0부터 Querydsl은 향후 fetchCount() , fetchResult() 를 지원하지 않기로 결정했다고 하는데 이에 맞는 강의

1

196

2

[환경설정 PDF 부트 3.0이후 설명 질문] build.gradle에 compileQuerydsl을 정의하지 않은 상태에서 Gradle->Tasks->other->compileQuerydsl을 클릭하라고 하는 이유가 무엇인가요??

1

200

1

querydsl 설정 문제

0

222

2

quey dsl 설정부분

0

158

2

count 쿼리 관련 질문입니다!

0

75

1

stringtemplate를 이용하여 where절 검색 방법 질문 드립니다.

0

89

1

답변부탁드리겠습니다.

0

89

2

(OrderSpecifier)관련 내용 어디있을가요

0

65

1

중급문법 벌크연산에서

0

81

2