inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! Querydsl

동적 쿼리와 성능 최적화 조회 - Builder 사용

N+1 현상

390

H K

작성한 질문수 93

1

안녕하세요 영한님

잘보고있습니다. 감사합니다

 

질문이 하나 있습니다.

 

    public List<MemberTeamDto> searchByBuilder(MemberSearchCondition condition){

 

        BooleanBuilder builder = new BooleanBuilder();

        if(StringUtils.hasText(condition.getUsername())){

            builder.and(member.username.eq(condition.getUsername()));

        }

        if(StringUtils.hasText(condition.getTeamName())){

            builder.and(team.name.eq(condition.getTeamName()));

        }

        if(condition.getAgeGoe() != null){

           builder.and(member.age.goe(condition.getAgeGoe()));

        }

        if(condition.getAgeLoe() != null){

            builder.and(member.age.loe(condition.getAgeLoe()));

        }

 

       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(builder)

               .fetch();

    }

//페치조인 미 적용

 

테스트를 해보면

 @Test

    public void searchTest(){

        Team teamA = new Team("teamA");

        Team teamB = new Team("teamB");

        em.persist(teamA);

        em.persist(teamB);

 

        Member member1 = new Member("member1", 10, teamA);

        Member member2 = new Member("member2", 20, teamA);

 

        Member member3 = new Member("member3", 30, teamB);

        Member member4 = new Member("member4" ,40, teamB);

 

        em.persist(member1);

        em.persist(member2);

        em.persist(member3);

        em.persist(member4);

 

        MemberSearchCondition condition = new MemberSearchCondition();

        condition.setAgeGoe(35);

        condition.setAgeLoe(40);

        condition.setTeamName("teamB");

 

        List<MemberTeamDto> result = memberJpaRepository.searchByBuilder(condition);

 

        assertThat(result).extracting("username").containsExactly("member4");

    }

 

N+1 같은 현상이 일어나지 않습니다.

페치 조인을 사용하지 않았는데

이유가 있을까요 ?

JPA java

답변 1

2

김영한

안녕하세요. H K님

지금처럼 엔티티가 아닌 DTO로 조회하시면 지연로딩을 사용할 수 없기 때문에 N+1 자체가 발생하지 않습니다.

감사합니다.

0

H K

아.. 아이코..!!

감사합니다

SpringBoot 4.X에서의 Querydsl 설정

0

156

2

querydsl 오픈소스에 대한 질문

1

101

1

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

0

127

1

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

0

348

2

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

1

86

1

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

0

172

1

querydsl sum() 메서드 없어요.

0

169

2

build 디렉터리 생성

0

152

2

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

0

122

2

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

0

99

1

오타 제보 드립니다.

0

79

2

벌크 연산과 flush, clear

0

84

1

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

0

95

1

QHello import하기 문제 발생

0

157

2

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

0

76

2

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

1

208

2

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

1

213

1

querydsl 설정 문제

0

228

2

quey dsl 설정부분

0

168

2

count 쿼리 관련 질문입니다!

0

79

1

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

0

98

1

답변부탁드리겠습니다.

0

95

2

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

0

68

1

중급문법 벌크연산에서

0

85

2