<aside> ❗
JPQL 스럽게 하면서 자바 코드로 작성할 수 있음
QOrder, QMember와 같은 Q파일을 생성해야 한다.
빌드할 때, Q 파일 생성하도록, 플러그 인을 넣어줘야 함</aside>
<aside> ❗
//querydsl 추가
buildscript {
dependencies {
plugin:1.0.10")
classpath("gradle.plugin.com.ewerk.gradle.plugins:querydsl-
}
}
plugins {
id 'java'
id 'org.springframework.boot' version '2.1.9.RELEASE'
}
apply plugin: 'io.spring.dependency-management'
apply plugin: "com.ewerk.gradle.plugins.querydsl"
group = 'jpabook'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '1.8'
configurations {
compileOnly {
extendsFrom annotationProcessor
}
}
repositories {
mavenCentral()
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
implementation 'org.springframework.boot:spring-boot-starter-thymeleaf'
implementation 'org.springframework.boot:spring-boot-starter-web'
implementation 'org.springframework.boot:spring-boot-devtools'
implementation 'com.fasterxml.jackson.datatype:jackson-datatype-hibernate5'
implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.5.6'
compileOnly 'org.projectlombok:lombok'
runtimeOnly 'com.h2database:h2'
annotationProcessor 'org.projectlombok:lombok'
testImplementation 'org.springframework.boot:spring-boot-starter-test'
//querydsl 추가
implementation 'com.querydsl:querydsl-jpa'
//querydsl 추가
implementation 'com.querydsl:querydsl-apt'
}
//querydsl 추가
//def querydslDir = 'src/main/generated'
def querydslDir =
"$buildDir/generated/querydsl"
querydsl {
library = "com.querydsl:querydsl-apt"
jpa = true
querydslSourcesDir = querydslDir
}
sourceSets {
main {
java {
srcDirs = ['src/main/java', querydslDir]
}
}
}
compileQuerydsl{
options.annotationProcessorPath = configurations.querydsl
}
configurations {
querydsl.extendsFrom compileClasspath
}
public List<Order> findAll(OrderSearch orderSearch) {
JPAQueryFactory query = new JPAQueryFactory(em);
// 먼저 Q파일애서 꺼내서 변수로 선언해줘야 한다.
QOrder order = QOrder.order;
QMember member = QMember.member;
// where(null)인 경우 실행되지 where 절을 실행하지 않음
return query.select(order)
.from(order)
.join(order.member, member) // order.member를 조인할 건데 위의 member를 별칭으로 주겠다는 의미
.where(statusEq(orderSearch.getOrderStatus()), nameLike(orderSearch.getMemberName()))
.limit(1000)
.fetch();
}
// 상태가 없으면 null 반환, 있으면 상태 반환
private BooleanExpression statusEq(OrderStatus statusCond){
if(statusCond == null){
return null;
}
return QOrder.order.status.eq(statusCond);
}
// 이름이 없으면 null 반환, 있으면 이름 반환
private BooleanExpression nameLike(String nameCond) {
if(StringUtils.hasText(nameCond)) {
return null;
}
//
return QMember.member.name.like(nameCond);
}
실무에서는 복잡한 동적 쿼리를 많이 사용하는데, 이때 Querydsl을 사용하면 높은 개발 생산성을 얻으면서 동시에 쿼리 오류를 컴파일 시점에 빠르게 잡을 수 있다.
꼭 동적 쿼리가 아니라 정적 쿼리인 경우에도 다음과 같은 이유로 Querydsl을 사용하는 것이 좋다.
Querydsl은 JPQL을 코드로 만드는 빌더 역할을 할 뿐 JPQL을 잘 이해하면 금방 배울 수 있다.
Querydsl은 JPA로 애플리케이션을 개발할 때 선택이 아닌 필수