본문 바로가기
[IT]/Querydsl

[QueryDSL] 인텔리제이 환경설정

by dop 2021. 3. 26.

기본 환경

  • JAVA 11
  • Gradle
  • InteliJ Community Edition

프로젝트 생성

스프링 부트 스타터(https://start.spring.io/)

사용기능 : Spring Web, Spring Data JPA, Lombok

SpringBoot Version : 2.4.4

 

저는 mariaDB를 사용했습니다.

이번 포스팅에서는 DB 관련 설정은 건너뛰고 Query DSL 설정만 하도록 하겠습니다.

 

build.gradle에 Query DSL 관련 내용을 추가해야 한다.

 

하기 전에 일단 SpringBoot가 정상 동작하는지 확인 후 진행하는 것을 추천한다!

 

우선 가장 위 plugin에 한 줄.

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

dependencies에 한 줄.

dependencies {
	implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
	implementation 'org.springframework.boot:spring-boot-starter-web'
	implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.5.8'
	compileOnly 'org.projectlombok:lombok'
	
	//querydsl 추가
	implementation 'com.querydsl:querydsl-jpa'

	runtimeOnly 'org.mariadb.jdbc:mariadb-java-client'
	annotationProcessor 'org.projectlombok:lombok'
	testImplementation 'org.springframework.boot:spring-boot-starter-test'
}

마지막으로 파일 가장 아랫부분에 넣어 준다.

//querydsl 추가
def querydslDir = "$buildDir/generated/querydsl"

querydsl {
	jpa = true
	querydslSourcesDir = querydslDir
}
sourceSets {
	main.java.srcDir querydslDir
}
configurations {
	querydsl.extendsFrom compileClasspath
}
compileQuerydsl {
	options.annotationProcessorPath = configurations.querydsl
}
// 끝

작성 후엔 WorkSpace 우측에 생기는 코끼리를 눌러주면 적용이 된다.

 

인텔리제이 최근 버전은 gradle로 실행하는 것이 기본 설정이다. 실행 속도가 느리기 때문에 다음과 같이 변경해 주도록 한다.

File - Settings - Build, Exe~ - Build Tools - Gradle에서 다음과 같이 변경해주면 된다. 

설정 후엔 꼭 APPLY를 눌러주자!

이제 설정은 끝났으니 잘 돌아가는지 검증해보도록 하자!

@Entity
@Getter
@Setter
public class HelloDSL {
    @Id @GeneratedValue
    private Long id;
}

다음과 같은 클래스를 하나 만들어주고 SpringBoot를 동작하면,

프로젝트 - build - generated - querydsl 파일 안에 QHelloDSL 파일이 생성되었다면 성공이다. 

SpringBoot를 구동시킬 때마다 현재 프로젝트 기준으로 최신화된다.

 

 

인텔리제이 가장 우측에 Gradle을 클릭하면 다음과 같은 게 나오는데, 여기서 앞서 말한 Q가 붙은 파일을 Q-Type이라고 하는 것을 관리할 수 있다. 

이건 꿀팁이니까 알고가면 좋다

Tasks - other - complieQuerydsl을 더블클릭하면 SpringBoot를 구동하지 않고도 Q-Type 생성해볼 수 있다.

그리고 개발 중에 Q-Type 관련해 문제가 생긴다면, Tasks - querydsl - cleanQuerydslSourceDir을 더블클릭하면 Q-Type 디렉터리를 제거할 수 있다. 제거한 후에 다시 한번 실행해 보도록 하자.

 

이상으로 Query DSL 설정 포스팅을 마치도록 하겠습니다.  

 

ps. 이것저것 활용해보면서 인텔리제이 활용도가 높아지는 게 느껴진다. 너무 편하다..

728x90

'[IT] > Querydsl' 카테고리의 다른 글

[Query DSL] package com.querydsl.core.types does not exist  (0) 2021.04.17
[QueryDSL] Query DSL 기본문법  (0) 2021.03.26
[QueryDSL] JPQL vs Query DSL  (0) 2021.03.26