인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

djqwkfj43u님의 프로필 이미지

작성한 질문수

실전! Querydsl

동적 쿼리 - Where 다중 파라미터 사용

BooleanExpression 관련 질문있습니다.

작성

·

43

·

수정됨

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

 

안녕하세요 강의 잘 보고 있습니다! 강의를 수강하다 몇가지 궁금한게 생겨 이렇게 질문 남깁니다.

1. BooleanExpression - where 다중 파라미터 사용

강의에서 강사님이 'where 다중 파라미터 사용'이라는 제목으로 이야기 하실 때 BooleanExpression을 소개하시는데 아래와 같이 구현하면 BooleanBuilder로도 where 다중 파라미터가 가능한 것 아닌가요??

private List<Member> searchMember1(String usernameCond, Integer ageCond) {

        return queryFactory
                .selectFrom(member)
                .where(usernameBuilder(usernameCond), ageBuilder(ageCond))
                .fetch();
}

    private BooleanBuilder usernameBuilder(String usernameCond) {
        if (usernameCond != null) {
            return new BooleanBuilder(member.username.eq(usernameCond));
        } else
            return new BooleanBuilder();
    }

    private BooleanBuilder ageBuilder(Integer ageCond) {
        if (ageCond != null) {
            return new BooleanBuilder(member.age.eq(ageCond));
        } else
            return new BooleanBuilder();
    }

2. BooleanExpression 을 선호하시는 이유

다음과 같이 BooleanExpression으로 allEq() 구현시 BooleanExpression은 추상클래스라 객체생성이 안되기 때문에 NPE가 발생할 수 있는데

private BooleanExpression usenameEq(String usernameCond) {
    return usernameCond != null ? member.username.eq(usernameCond) : null;
}

private BooleanExpression ageEq(Integer ageCond) {
    return ageCond != null ? member.age.eq(ageCond) : null;
}

private BooleanExpression allEq(String usernameCond, Integer ageCond) {
    return usenameEq(usernameCond).and(ageEq(ageCond)); // NPE 조심
}

반면 BooleanBuilder은 실제 클래스라 객체 생성이 되기 때문에 NPE도 방지가 가능합니다.

private BooleanBuilder usernameBuilder(String usernameCond) {
    if (usernameCond != null) {
        return new BooleanBuilder(member.username.eq(usernameCond));
    } else
        return new BooleanBuilder();
}

private BooleanBuilder ageBuilder(Integer ageCond) {
    if (ageCond != null) {
        return new BooleanBuilder(member.age.eq(ageCond));
    } else
        return new BooleanBuilder();
}

private BooleanBuilder allBuilder(String usernameCond, Integer ageCond) {
    return usernameBuilder(usernameCond).and(ageBuilder(ageCond));
}

이렇게만 보면 사실 BooleanExpression을 쓸 이유가 없어보이는데 BooleanExpression을 선호하시는 이유가 있으신가요??

답변 1

0

인프런 AI 인턴님의 프로필 이미지

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

BooleanExpression과 BooleanBuilder의 사용에 관한 질문을 주셨네요. 먼저 BooleanExpression과 BooleanBuilder는 모두 Querydsl에서 동적 쿼리를 생성하는 데 유용한 도구입니다. 다만, 주로 사용하는 목적 및 사용 방식이 다소 다를 수 있습니다.

BooleanExpression vs. BooleanBuilder

  1. BooleanExpression:

    • 일반적으로 더 간결한 코드 작성을 도와주며, 메서드 내에 조건식을 정의하고 재사용하기에 유리합니다.
    • 주의점: BooleanExpression을 사용할 때 반환값이 null이 될 수 있으므로, null 체크를 철저히 하지 않으면 NPE(Null Pointer Exception)가 발생할 수 있습니다.
  2. BooleanBuilder:

    • 초기에는 빈 상태로 생성되어, 이후 조건문을 추가적으로 계속 엮어가면서 사용할 수 있습니다.
    • NPE 발생 가능성이 적습니다. 초기 생성 시점에 항상 객체가 생성되므로, 해당 객체를 활용해 조건을 추가할 수 있습니다.

왜 BooleanExpression을 선호하나요?

  • 가독성: BooleanExpression을 사용하면 조건식을 메서드로 분리할 수 있어 코드 가독성이 높아지고 유지보수하기가 용이합니다.
  • 유연성: 다양한 조건을 포함한 동적 쿼리를 만들 때 더욱 유연하게 사용할 수 있습니다.
  • 그러나 BooleanBuilder도 NPE의 위험을 줄이고, 동적 쿼리 작성을 쉽게 만들어주는 이점이 있습니다.

참고자료

결론적으로, 본인이 작성하는 코드의 구조와 요구사항에 따라 두 클래스 중 적합한 것을 선택하시면 됩니다. BooleanExpression이 간결함과 재사용성 측면에서 선호될 수 있지만, 안전성이 필요할 때는 BooleanBuilder를 사용하는 것도 고려해 볼 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.