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

bbb3631님의 프로필 이미지
bbb3631

작성한 질문수

실전! Querydsl

Booleanbuilder이용시 조건 다른 컬럼 조회

작성

·

303

0

 

private BooleanExpression checkActivityContainsGeneration(Integer generation) {
 if(generation == null) return null;
return QMemberActivity.memberActivity.generaition.eq(generation);
}

이렇게 전체 멤버를 조회할때, 해당 generation 값을 가져오는 boolean expression을 조회했습니다.

하지만, generation 을 이용한 정렬을 할때에는, 해당 userid를 가진 모든 generation 컬럼을 가져와야하는데, 위의 조건처럼 조건을 준다면 해당 generation 컬럼만 가져와서 정렬이 제대로 되지 않더라구요!

제가 원하는건

return QMemberActivity.memberActivity.memberId.eq(
select  memberId from QMemberActivity.memberActivity 
where QMemberActivity.memberActivity.generation.eq(generation)
);

과 같이 generation이 같은 컬럼의 memberId를 가져오는 것인데,

booleanexpression으로 다른 컬럼 값을 return하려면 subquery를 작성하는 것 뿐일까요?

답변 2

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. bbb3631님

질문이 잘 이해가 되지 않습니다.

전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx

주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

추가로 다음 내용도 코멘트 부탁드립니다.

1. 실행 방법을 알려주세요.

2. 어떻게 문제를 확인할 수 있는지 자세한 설명을 남겨주세요.

감사합니다.

 

0

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

BooleanBuilder를 사용하여 조건을 줄 때, 해당 컬럼만 가져와서 정렬이 제대로 되지 않는 경우는 일반적인 상황입니다. 이럴 경우, subquery를 사용하여 원하는 컬럼 값을 가져올 수 있습니다.

따라서, 원하시는 기능을 구현하려면 subquery를 작성해야 합니다.

추가적으로, BooleanBuilder를 사용할 때 해당 컬럼만 가져와서 정렬이 제대로 되지 않는 상황이 발생한다면, Joins를 사용하여 해당 문제를 해결할 수도 있습니다.

이상입니다. 참고하시길 바랍니다. 감사합니다.

bbb3631님의 프로필 이미지
bbb3631

작성한 질문수

질문하기