Jin's Dev Story

[Spring Data JPA] Querydsl 본문

Web & Android/Spring Data JPA

[Spring Data JPA] Querydsl

woojin._. 2023. 10. 15. 09:41
  • 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가지 사용 방법

  1. QItem qItem = new QItem("i");
  2. QItem qItem = QItem.item;
  3. 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