JPA
[Querydsl] where 조건과 결과 조회
mangdo
2021. 8. 4. 17:03
Querydsl 검색 조건 활용
@Test
public void search() {
Member findMember = queryFactory
.selectFrom(member)
.where(member.username.eq("member1")
.and(member.age.eq(10)))
.fetchOne();
assertThat(findMember.getUsername()).isEqualTo("member1");
}
Querydsl 검색 조건
member.username.eq("member1") // username = 'member1'
member.username.ne("member1") //username != 'member1'
member.username.eq("member1").not() // username != 'member1'
member.username.isNotNull() //이름이 is not null
member.age.in(10, 20) // age in (10,20)
member.age.notIn(10, 20) // age not in (10, 20)
member.age.between(10,30) //between 10, 30
member.age.goe(30) // age >= 30 (greater or equal)
member.age.gt(30) // age > 30
member.age.loe(30) // age <= 30 (lower or equal)
member.age.lt(30) // age < 30
member.username.like("%member") //like 검색
member.username.contains("member") // like ‘%member%’ 검색
member.username.startsWith("member") //like ‘member%’ 검색
결과 조회
- fetch() : 리스트 조회, 데이터 없으면 빈 리스트 반환
- fetchOne() : 단 건 조회
- 결과가 없으면 : null
- 결과가 둘 이상이면 : com.querydsl.core.NonUniqueResultException
- fetchFirst() : limit(1).fetchOne()
- fetchResults() : 페이징 정보 포함, total count 쿼리 추가 실행
- 페이징 쿼리가 복잡해지면 데이터가져오는 쿼리와 totalcount 쿼리가 성능때문에 두개로 나누는 경우가 있다.
- 때문에 복잡한 쿼리에서는 fetchResults()를 쓰면 안된다. 그 때는 두번을 따로 해야한다.
- fetchCount() : count 쿼리로 변경해서 count 수 조회
//List
List<Member> fetch = queryFactory
.selectFrom(member)
.fetch();
//단 건
Member findMember1 = queryFactory
.selectFrom(member)
.fetchOne();
//페이징에서 사용
QueryResults<Member> results = queryFactory
.selectFrom(member)
.fetchResults();
//count 쿼리로 변경
long count = queryFactory
.selectFrom(member)
.fetchCount();
distinct
//List
List<Member> fetch = queryFactory
.selectFrom(member).distinct()
.fetch();