반응형
05-03 07:00
Today
Total
«   2024/05   »
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
관리 메뉴

개발하는 고라니

[Spring Boot] Gradle의 Querydsl 설정 본문

Framework/Spring Boot

[Spring Boot] Gradle의 Querydsl 설정

조용한고라니 2020. 12. 27. 02:05
반응형
//플러그인 추가
plugins 
{
	id 'com.ewerk.gradle.plugins.querydsl' version '1.0.10'
}
//의존성 주입
dependencies
{
	implementation 'com.querydsl:querydsl-jpa'
}
//Gradle에서 사용할 추가적인 task
def querydslDir = "$buildDir/generated/querydsl"

querydsl{
    jpa = true
    querydslSourcesDir = querydslDir
}

sourceSets {
    main.java.srcDir querydslDir
}

configurations{
    querydsl.extendsFrom compileClasspath
}

compileQuerydsl{
    options.annotationProcessorPath = configurations.querydsl
}

* build.gradle 파일을 갱신하면 다음과 같이 실행 가능한 task가 추가되어있다.

62행 초록색 재생표시

* task를 실행하면 다음과 같이 QClass가 생성되어있다.

 

 

위 방법이 안되면 Spring Boot / Gradle 버전이 달라진 것, 아래 방법으로 해결

buildscript {
    //Add
    ext {
        queryDslVersion = "5.0.0"
    }
}

plugins {
    id 'org.springframework.boot' version '2.6.3'
    id 'io.spring.dependency-management' version '1.0.11.RELEASE'
    //Add
    id 'com.ewerk.gradle.plugins.querydsl' version '1.0.10'
    id 'java'
}

...

dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
    implementation 'org.springframework.boot:spring-boot-starter-web'
    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:${queryDslVersion}"
    implementation "com.querydsl:querydsl-apt:${queryDslVersion}"
}

tasks.named('test') {
    useJUnitPlatform()
}

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

☞ 정적 타입을 이용해서 SQL과 같은 쿼리를 생성해주는 프레임워크이다. 문자열 또는 XML에 작성하는 대신 Querydsl이 제공하는 플루언트(Fluent) API를 이용해 query를 생성할 수 있다.

☞ 쿼리를 자바 코드로 만들 수 있게 해준다. 

☞ JPA의 쿼리메서드와 @Query 어노테이션을 이용해 다양한 기능을 구현할 수 있으나, 선언할 때의 정적인 값을 갖는다는 단점을 보완한다.

☞ 복잡한 조합을 이용하는 경우의 수가 많은 상황에서 동적으로 쿼리를 생성하여 처리한다.

☞ Querydsl을 이용하려면 기존에 작성한 Entity 클래스를 그대로 이용하는 것이 아닌 Q도메인 클래스를 이용해야만 한다.

☞ Querydsl의 핵심 원칙은 타입 안정성(Type Safety)이다. 도메인 타입의 프로퍼티를 반영해 생성한 쿼리 타입을 이용해 쿼리를 작성하게 된다. 또한, 완전하게 타입에 안전한 방법으로 함수 or 메서드 호출이 이뤄진다.

* http://www.querydsl.com/static/querydsl/4.0.1/reference/ko-KR/html_single/ (Querydsl Reference doc)

 

반응형
Comments