QueryDsl 설정
원래는 지난번과 다르게 JPA를 사용 정렬과 필터를 시도해 보려했다. 다음은 내가 찾아본 JPA를 사용해서 정렬하는 방법이다.
1
2
3
4
5
6
@Controller
public List<T> list(Pageable pageable)
{
List<T> tList = jpaRepository.findAll(pageable);
return tList;
}
1
public Page<T> findAllByNameOrderByCreatedDateDesc();
메서드 이름만으로 JPQL 쿼리 생성로도 검색, 정렬이 가능하고
1
2
3
4
5
6
7
public interface MemberRepsoitory extends JpaRepository<Member, Long> {
List<Member> findByUsername(String username); // 검색
List<member> findByUsername(String username, Sort sort); // 검색 + 정렬
List<Member> findByUsername(String username, Pageable Pagealbe); // 검색 + 정렬 + 페이징
}
@Query를 사용해서 직접 JPQL 지정하는 방법으로도 사용할 수 있다.
1
2
3
4
public interface MemberRepsoitory extends JpaRepository<Member, Long> {
@Query("SELECT m FROM Member m WHERE m.username = ?1")
List<Member> findByUsername(String username);
}
이렇게 쿼리문을 직접 쓰게 되면 결국 Querydsl을 사용하는 방법과 별 다르지 않다는 생각이 들었다.
Querydsl은 SQL, JPQL을 코드로 작성할 수 있도록 도와준다는 의미가 무엇인지 예시 코드들로 이해할 수 있었다. 결국 쿼리문으로 좀더 편안하게 작성하기 위해 Querydsl로 구현하기로 하였다. 그러기 위해서는 Querydsl 설정이 필요하다!
버전 변경으로 일어난 변화
지난번에는 Java(11) / Spring Boot(2.7.6) 버전을 사용했었는데,
이번에는 Java(17) / Spring Boot(3.0.2) 버전을 사용해서 설정부분이 좀 달라졌다.
지난번에도 이번에도 Querydsl의 버전은 5.0.0을 사용하였다.
이번에 버전 변경으로 우리 프로젝트에서 업데이트 한 부분이다.
일단 Spring Boot(3.0)은 자바 17버전부터 지원한다고 한다. 스프링부트 3.0버전이상을 사용하려면 자바 17버전은 필수이다. 사실 맨처음 스프링 이니셜라이저에서 자바11버전에 스프링부트3.0을 설정하고 프로젝트를 열었는데, 빌드 그래들부분에 자바 17버전이 적혀 있어서 당황했다 ㅇㅅㅇ
또 WebSecurityConfig파일에서의 AntMatcher를 requestMatchers로 변경했다. AntMatchers를 더이상 지원하지 않아 빨간줄이 뜬다. 검색해보니 이제 더이상 지원하지 않아서 requestMatchers로 변경해주었다.
스프링부트 3.0버전부터는 gradle - tasks- other - compileQuerydsl을 눌르지 않고,
gradle - tasks - build - build 만으로도 Q파일이 생성된다고 한다.javax가 지원이 안되고 jakarta만 가능해 전에 사용했던 내용을 그대로 가져오면 안된다. 잘보고 jakarta로 import해야 실행이 잘 될 것이다.
그리고 빌드 그래들에서의 Querydsl 설정부분의 많은 부분이 바뀌었다.
Spirng Boot 3.0 + Querydsl 5.0.0 build.gradle 설정
아.. 될때까지 이것저것 넣어보느라 고생좀 했다..
그리고 마침내 해결하였다.
스프링부트 3.0 + Querydsl 5.0.0 에서 빌드할때 또는 실행할때 계속해서 오류가 났었다 😓
이전 프로젝트에서
Java(11) / Spring(2.7.6) + Querydsl 사용시의 build.gradle
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
//queryDsl version 정보 추가
// 👉 이번에는 버전관리를 따로 하지 않아 필요없는 부분으로 삭제
buildscript {
ext {
queryDslVersion = "5.0.0"
}
}
plugins {
id 'java'
id 'org.springframework.boot' version '2.7.5' // 👉 스프링부트 3.0.2버전 사용
id 'io.spring.dependency-management' version '1.0.15.RELEASE'
//querydsl plugins 추가 👉 이번 버전에서는 삭제
id "com.ewerk.gradle.plugins.querydsl" version "1.0.10"
}
group = 'com.sparta'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '11' // 👉 자바 17버전 사용
configurations {
compileOnly {
extendsFrom annotationProcessor
}
}
repositories {
mavenCentral()
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
implementation 'org.springframework.boot:spring-boot-starter-security'
implementation 'org.springframework.boot:spring-boot-starter-web'
compileOnly 'org.projectlombok:lombok'
developmentOnly 'org.springframework.boot:spring-boot-devtools'
runtimeOnly 'com.h2database:h2'
// querydsl 👉 새로운 내용으로 변경
implementation "com.querydsl:querydsl-jpa:${queryDslVersion}"
implementation "com.querydsl:querydsl-apt:${queryDslVersion}"
//mysql
runtimeOnly 'com.mysql:mysql-connector-j'
//s3
implementation 'io.awspring.cloud:spring-cloud-starter-aws:2.4.2'
//jwt
compileOnly group: 'io.jsonwebtoken', name: 'jjwt-api', version: '0.11.2'
runtimeOnly group: 'io.jsonwebtoken', name: 'jjwt-impl', version: '0.11.2'
runtimeOnly group: 'io.jsonwebtoken', name: 'jjwt-jackson', version: '0.11.2'
annotationProcessor 'org.projectlombok:lombok'
testImplementation 'org.springframework.boot:spring-boot-starter-test'
testImplementation 'org.springframework.security:spring-security-test'
// validation
implementation 'org.springframework.boot:spring-boot-starter-validation'
// redis
implementation 'org.springframework.boot:spring-boot-starter-data-redis'
//p6spy
implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.8.1'
//swagger
implementation 'io.springfox:springfox-swagger2:3.0.0'
implementation 'io.springfox:springfox-swagger-ui:3.0.0'
}
tasks.named('test') {
useJUnitPlatform()
}
/*
* queryDSL 설정 추가 👉 이번 버전에서는 이 부분도 필요없어서 전부 삭제
*/
// querydsl에서 사용할 경로 설정
def querydslDir = "$buildDir/generated/querydsl"
// JPA 사용 여부와 사용할 경로를 설정
querydsl {
library = "com.querydsl:querydsl-apt"
jpa = true
querydslSourcesDir = querydslDir
}
// build 시 사용할 sourceSet 추가
sourceSets {
main.java.srcDir querydslDir
}
// querydsl 컴파일시 사용할 옵션 설정
compileQuerydsl {
options.annotationProcessorPath = configurations.querydsl
}
// querydsl 이 compileClassPath 를 상속하도록 설정
configurations {
compileOnly {
extendsFrom annotationProcessor
}
querydsl.extendsFrom compileClasspath
}
jar {
enabled = false
}
tasks.named('test') {
useJUnitPlatform()
}
현재
Java(17) / Spring(3.0.2) + Querydsl 사용시의 build.gradle
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
plugins {
id 'java'
id 'org.springframework.boot' version '3.0.2'
id 'io.spring.dependency-management' version '1.1.0'
}
group = 'com.ilcle'
version = '0.0.1-SNAPSHOT'
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-security'
implementation 'org.springframework.boot:spring-boot-starter-web'
compileOnly 'org.projectlombok:lombok'
developmentOnly 'org.springframework.boot:spring-boot-devtools'
runtimeOnly 'com.h2database:h2'
annotationProcessor 'org.projectlombok:lombok'
testImplementation 'org.springframework.boot:spring-boot-starter-test'
testImplementation 'org.springframework.security:spring-security-test'
// querydsl 👉 변경된 내 추가
implementation 'com.querydsl:querydsl-core'
implementation 'com.querydsl:querydsl-jpa:5.0.0:jakarta'
annotationProcessor "com.querydsl:querydsl-apt:${dependencyManagement.importedProperties['querydsl.version']}:jakarta"
annotationProcessor "jakarta.annotation:jakarta.annotation-api"
annotationProcessor "jakarta.persistence:jakarta.persistence-api"
//mysql
implementation 'mysql:mysql-connector-java'
//jwt
compileOnly group: 'io.jsonwebtoken', name: 'jjwt-api', version: '0.11.2'
runtimeOnly group: 'io.jsonwebtoken', name: 'jjwt-impl', version: '0.11.2'
runtimeOnly group: 'io.jsonwebtoken', name: 'jjwt-jackson', version: '0.11.2'
//스웨거
implementation 'org.springdoc:springdoc-openapi-starter-webmvc-ui:2.0.2'
implementation 'org.springdoc:springdoc-openapi-starter-common'
}
tasks.named('test') {
useJUnitPlatform()
}