기본 문법
런타임오류가 아닌 컴파일 오류를 발생시키기 때문에 JPQL보다 예외상황을 찾기 쉽다.
들어가기
em(entity manager)을 사용해 JPAQueryFactory 객체를 만든다.
compile해 Q타입을 가져오고 변수명에 별칭을 단다.
자바 메서드 형태로 원하는 쿼리를 날린다.
기본 Q-Type 활용
JPQL의 별칭을 직접 지정할 수 있다.
QMember qMember = new QMember("m");
혹은 기본 인스턴스를 사용할 수 있다.
QMember qMember = QMember.member;
기본 인스턴스를 static import해 사용하는 것이 가장 권장된다.
검색 조건 쿼리
selectFrom → select 와 from을 합친 메서드
검색 조건을
.and()
,.or()
메서드로 체이닝할 수 있다..and()
가 여러개일 경우,
를 사용해 여러 조건을 넘겨도 된다.JPQL이 제공하는 모든 검색 조건을 제공한다.
결과 조회
fetch() : 리스트 조회, 데이터 없으면 빈 리스트 반환
fetchOne() : 단 건 조회
결과가 없으면 : null
결과가 둘 이상이면 : com.querydsl.core.NonUniqueResultException
fetchFirst() : limit(1).fetchOne()과 동일
fetchResults() : 페이징 정보 포함, total count 쿼리 추가 실행
fetchCount(): count 쿼리로 변경해서 count 수 조회
정렬
orderBy() 메서드 내부에 정렬 조건을 넣을 수 있다.
desc() , asc() : 일반 정렬 (내림차순, 오름차순)
nullsLast() , nullsFirst() : null 데이터 순서 부여
페이징
조회 건수 제한
orderBy가 필요하다.
offset: 0부터 시작, 몇 번째 row에서 데이터 조회를 시작할지 정함
조인
첫 번째 파라미터에 조인 대상을 지정하고, 두 번째 파라미터에 별칭(alias)으로 사용할 Q 타입을 지정
join() , innerJoin() : 내부 조인(inner join)
leftJoin() : left 외부 조인(left outer join)
rightJoin() : rigth 외부 조인(rigth outer join)
JPQL의 on과 성능 최적화를 위한 fetch 조인 제공
세타 조인
rom 절에 여러 엔티티를 선택하면 세타 조인이다.
on 절 사용한 조인
조인 대상 필터링
on 절을 활용해 조인 대상을 필터링 할 때, 내부조인(inner join)을 사용하면, where 절에서 필터링 하는 것과 기능이 동일하므로 익숙한 where 절로 해결할 것
외부조인이 필요한 경우에만 on 절을 사용하자
연관관계 없는 엔티티 외부조인
username과 team 이름이 같은 것이 없다면? member와 null(
team이었던 것..)이 결과로 반환됨
페치 조인
SQL조인을 활용해서 연관된 엔티티를 SQL 한번에 조회하는 기능
join(), leftJoin() 등의 뒤에 fetchJoin()을 추가하면 된다.
서브쿼리
com.querydsl.jpa.JPAExpressions
사용
from 절의 서브쿼리 해결방안
서브쿼리를 join으로 변경한다. (가능한 상황도 있고, 불가능한 상황도 있다.)
애플리케이션에서 쿼리를 2번 분리해서 실행한다.
nativeSQL을 사용한다.
DB에서 데이터를 가져올 때는 데이터를 최소화해서 가져오는 역할만 처리하는 것이 좋다.
case문
select, 조건절(where), order by에서 사용 가능
복잡한 조건을 CaseBuilder 변수로 선언
상수, 문자 더하기
상수를 결과값에 같이 반환하기
사실 사용할 일이 있긴 할까 싶다
문자를 더해서 반환하기
stringValue()
: Enum 타입과 같이 문자가 아닌 다른 타입일 경우 이 함수를 사용해 가져와야 한다.
Last updated