Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- Oracle
- CS
- 데이터
- 시큐리티
- DB
- 스프링부트
- 플러터
- 프로그래머스
- python
- JPA
- baekjoon
- 자바
- Spring Security
- Java
- postgresql
- CS지식
- 자바스크립트
- programmers
- 네트워크
- Flutter
- 스프링
- 리눅스
- 데이터베이스
- springboot
- 자료구조
- backjoon
- 백준
- 파이썬
- 스프링 부트 쇼핑몰 프로젝트 with JPA
- spring
Archives
- Today
- Total
Jin's Dev Story
[Spring Data JPA] Querydsl 본문
- 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 |