Build.gradle
...
dependencies {
...
//Querydsl 추가
implementation 'com.querydsl:querydsl-jpa'
annotationProcessor "com.querydsl:querydsl-apt:${dependencyManagement.importedProperties['querydsl.version']}:jpa"
annotationProcessor "jakarta.annotation:jakarta.annotation-api"
annotationProcessor "jakarta.persistence:jakarta.persistence-api"
...
}
...
//Querydsl 추가, 자동 생성된 Q클래스 gradle clean으로 제거
clean {
delete file('src/main/generated')
}
검증 - Q 타입 생성 확인 방법
Preferences -> Build, Execution, Deployment -> Build Tools -> Gradle

- Gradle: Gradle을 통해서 빌드한다.
- IntelliJ IDEA: IntelliJ가 직접 자바를 실행해서 빌드한다.
옵션 선택 1 - Gradle - Q타입 생성 확인 방법
Gradle IntelliJ 사용법
Gradle -> Tasks -> build -> clean
Gradle -> Tasks -> other -> compileJava
Gradle 콘솔 사용법
./gradlew clean compileJava
Q 타입 생성 확인
build -> generated -> sources -> annotationProcessor -> java/main 하위에 hello.itemservice.domain.QItem 이 생성되어 있어야 한다.
참고: Q타입은 컴파일 시점에 자동 생성되므로 버전 관리(GIT)에 포함하지 않는 것이 좋다.
gradle 옵션을 선택하면 Q타입은 gradle build 폴더 아래에 생성되기 때문에 여기를 포함하지 않아야 한다. 대부분 gradle build 폴더를 git에 포함하지 않기 때문에 이 부분은 자연스럽게 해결된다.
Q타입 삭제
gradle clean 을 수행하면 build 폴더 자체가 삭제된다. 따라서 별도의 설정은 없어도 된다
옵션 선택2 - IntelliJ IDEA - Q타입 생성 확인 방법

- Build -> Build Project 또는 Build -> Rebuild 또는 main() , 또는 테스트를 실행하면 된다.
- src/main/generated 하위에 hello.itemservice.domain.QItem 이 생성되어 있어야 한다.
참고: Q타입은 컴파일 시점에 자동 생성되므로 버전 관리(GIT)에 포함하지 않는 것이 좋다.
IntelliJ IDEA 옵션을 선택하면 Q타입은 src/main/generated 폴더 아래에 생성되기 때문에 여기를 포함하지 않는 것이 좋다.
Q타입 삭제
//Querydsl 추가, 자동 생성된 Q클래스 gradle clean으로 제거
clean {
delete file('src/main/generated')
}
IntelliJ IDEA 옵션을 선택하면 src/main/generated 에 파일이 생성되고, 필요한 경우 Q파일을 직접 삭제해야 한다.
gradle에 해당 스크립트를 추가하면 gradle clean 명령어를 실행할 때 src/main/generated의 파일도 함께 삭제해준다.
참고
Querydsl은 이렇게 설정하는 부분이 사용하면서 조금 귀찮은 부분인데, IntelliJ가 버전업 하거나 Querydsl의 Gradle 설정이 버전업 하면서 적용 방법이 조금씩 달라지기도 한다. 그리고 본인의 환경에 따라서 잘 동작하지 않기도 한다. 공식 매뉴얼에 소개되어 있는 부분이 아니기 때문에, 설정에 수고로움이 있지만 querydsl gradle로 검색하면 본인 환경에 맞는 대안을 금방 찾을 수 있을 것이다.
'스프링 DB 2편(데이터 접근 활용 기술)' 카테고리의 다른 글
| Ch08. 활용 방안 - 스프링 데이터 JPA 예제와 트레이드 오프 (0) | 2022.07.04 |
|---|---|
| Ch07. Querydsl - Querydsl 적용 (0) | 2022.07.02 |
| Ch06. SpringDataJPA - 스프링 데이터 JPA 적용 (0) | 2022.07.01 |
| Ch06. SpringDataJPA - 스프링 데이터 JPA 주요 기능 (0) | 2022.07.01 |
| Ch05. JPA - JPA 적용 (0) | 2022.06.30 |