- Querydsl은 JPQL을 코드로 작성할 수 있도록 도와주는 빌더 API
- 문자열이 아닌 자바 소스코드로 작성하기 때문에 컴파일 시점에 오류 발견 가능
- 쿼리를 재사용할 수 있으며 제약 조건 조립 및 가독성을 향상시킬 수 있음
- 고정된 SQL문이 아닌 조건에 맞게 동적으로 쿼리 생성 가능
- 자동완성기능을 이용하여 생산성 향상시킬 수 있음
이전 버전
// querydsl 추가 1 buildscript { ext { queryDslVersion = "5.0.0" } } plugins { id 'java' id 'org.springframework.boot' version '3.1.2' id 'io.spring.dependency-management' version '1.1.2' } group = 'kr.inhatc' version = '0.0.1-SNAPSHOT' java { sourceCompatibility = '17' } 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' compileOnly 'org.projectlombok:lombok' developmentOnly 'org.springframework.boot:spring-boot-devtools' runtimeOnly 'com.mysql:mysql-connector-j' annotationProcessor 'org.projectlombok:lombok' testImplementation 'org.springframework.boot:spring-boot-starter-test' // querydsl 추가 2 implementation "com.querydsl:querydsl-jpa:${queryDslVersion}:jakarta" annotationProcessor( "jakarta.persistence:jakarta.persistence-api", "jakarta.annotation:jakarta.annotation-api", "com.querydsl:querydsl-apt:${queryDslVersion}:jakarta") } tasks.named('test') { useJUnitPlatform() } // querydsl 추가 3 sourceSets { main { java { srcDirs = ["$projectDir/src/main/java", "$projectDir/build/generated"] } } } compileJava.dependsOn('clean')
💡 !!! gradle에 추가 후 생성된 Q 클래스는 git에 올리면 안됨!!
gradle에 코드 추가 후 Gradle탭 → other → compileQuerydsl or compile→ 프로젝트 build 탭 → querydsl → QItem을 확인할 수 있음
buildscript { // querysql ext { queryDslVersion = "5.0.0" } } plugins { id 'java' id 'org.springframework.boot' version '3.0.1' id 'io.spring.dependency-management' version '1.1.0' //querydsl 추가 id "com.ewerk.gradle.plugins.querydsl" version "1.0.10" } group = 'kr.spring' version = '0.0.1-SNAPSHOT' sourceCompatibility = '17' configurations { compileOnly { extendsFrom annotationProcessor } } repositories { mavenCentral() } dependencies { implementation 'org.springframework.boot:spring-boot-starter-thymeleaf' implementation 'org.springframework.boot:spring-boot-starter-web' implementation 'org.springframework.boot:spring-boot-starter-data-jpa' runtimeOnly 'com.mysql:mysql-connector-j' compileOnly 'org.projectlombok:lombok' developmentOnly 'org.springframework.boot:spring-boot-devtools' annotationProcessor 'org.projectlombok:lombok' testImplementation 'org.springframework.boot:spring-boot-starter-test' //querydsl 추가 annotationProcessor("jakarta.persistence:jakarta.persistence-api") annotationProcessor("jakarta.annotation:jakarta.annotation-api") implementation 'com.querydsl:querydsl-jpa:5.0.0:jakarta' annotationProcessor "com.querydsl:querydsl-apt:${dependencyManagement.importedProperties['querydsl.version']}:jakarta" } tasks.named('test') { useJUnitPlatform() } //querydsl 추가 시작 def querydslDir = "$buildDir/generated/querydsl" querydsl { jpa = true querydslSourcesDir = querydslDir } sourceSets { main.java.srcDir querydslDir } compileQuerydsl{ options.annotationProcessorPath = configurations.querydsl } configurations { compileOnly { extendsFrom annotationProcessor } querydsl.extendsFrom compileClasspath } //querydsl 추가 끝
QItem의 3가지 사용 방법
- QItem qItem = new QItem("i");
- QItem qItem = QItem.item;
- import static kr.spring.item.entity.QItem.item; 사용하는 경우엔 item이라는 변수를 붙여주면 됨
import static kr.spring.item.entity.QItem.item; @Test @DisplayName("querydsl 테스트") public void querydslTest() { this.createItemList(); JPAQueryFactory queryFactory = new JPAQueryFactory(em); // QItem qItem = new QItem("i"); 아래 문장과 동일 // QItem qItem = QItem.item; // qItem은 QItem.item과 같은 것 List<Item> list = queryFactory .selectFrom(item) // .select(item).from(item)으로 써도 됨 .where(item.itemSellStatus.eq(ItemSellStatus.SELL)) // ItemSellStatus.SELL이랑 qItem.itemSellStatus 비교 .where(item.itemDetail.like("%" + "1" + "%")) .orderBy(item.price.asc()) // 가격에 대해 오름차순 .fetch(); for(Item item : list) { System.out.println(item); } }
→ 조건이 많아져 이해하기 힘들어질 때 QuerydslPredicateExecutor 사용
'Web & Android > Spring Data JPA' 카테고리의 다른 글
[Spring Data JPA] 영속성 전이, 고아객체 (0) | 2023.10.15 |
---|---|
[Spring Data JPA] 연관 관계 매핑 (0) | 2023.10.15 |
[Spring Data JPA] @Query (0) | 2023.10.14 |
[Spring Data JPA] JPA (0) | 2023.10.14 |
[Spring Data JPA] QueryMethod (0) | 2023.10.14 |