개발(합니다)/Java&Spring
[spring boot 설정하기-6] querydsl(+JPA) 설정 및 테스트 소스
otrodevym
2021. 4. 9. 00:00
반응형
쿼리를 소스로 작성해야 하는 경우가 있는데 세련 된 방식으로 사용할 수 있도록 도와줍니다.
SQL, JPQL을 코드로 작성을 도와주는 빌더 API입니다.
JPA에서 제공하는 @Query에서 다양한 조회를 하기에는 다소 한계가 있는데
이를 해결하기 위한 조회 프레임워크로 querydsl이 있습니다.
JPA를 좀더 효율적으로 사용할 수 있도록 도와줍니다.
관련 정보는 아래 사이트에서 얻을 수 있습니다.
www.querydsl.com/static/querydsl/4.0.1/reference/ko-KR/html_single/
1. 의존성 추가
apply plugin: "io.spring.dependency-management"
compile("com.querydsl:querydsl-core") // querydsl
compile("com.querydsl:querydsl-jpa") // querydsl
annotationProcessor "com.querydsl:querydsl-apt:${dependencyManagement.importedProperties['querydsl.version']}:jpa" // querydsl JPAAnnotationProcessor 사용 지정
annotationProcessor("jakarta.persistence:jakarta.persistence-api")
annotationProcessor("jakarta.annotation:jakarta.annotation-api")
def generated='src/main/generated'
sourceSets {
main.java.srcDirs += [ generated ]
}
tasks.withType(JavaCompile) {
options.annotationProcessorGeneratedSourcesDirectory = file(generated)
}
clean.doLast {
file(generated).deleteDir()
}
2. gradle의 complieJava 실행
Q로 시작하는 entity들이 생성됩니다.
3. QuerydslConfig 생성
package com.otrodevym.spring.base.common.Querydsl;
import com.querydsl.jpa.impl.JPAQueryFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
@Configuration
public class QuerydslConfig {
@PersistenceContext
private EntityManager entityManager;
@Bean
public JPAQueryFactory jpaQueryFactory() {
return new JPAQueryFactory(entityManager);
}
}
3. 테스트 방법
3-1 DB 생성
create table querydsl_test (
id int not null auto_increment,
name char(50) not null,
primary key (id)
);
3-2. QuerydslTest 생성
package com.otrodevym.spring.base.common.Querydsl;
import lombok.AccessLevel;
import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
@Entity
@Getter
@NoArgsConstructor(access = AccessLevel.PROTECTED)
public class QuerydslTest {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
@Builder
public QuerydslTest(String name) {
this.name = name;
}
}
3-3. QuerydslRepository 생성
package com.otrodevym.spring.base.common.Querydsl;
import org.springframework.data.jpa.repository.JpaRepository;
public interface QuerydslRepository extends JpaRepository<QuerydslTest, Long> {
}
3-4. QuerydslRepositorySupportMy 생성
package com.otrodevym.spring.base.common.Querydsl;
import com.querydsl.jpa.impl.JPAQueryFactory;
import org.springframework.data.jpa.repository.support.QuerydslRepositorySupport;
import org.springframework.stereotype.Repository;
import java.util.List;
import static com.otrodevym.spring.base.common.Querydsl.QQuerydslTest.querydslTest;
@Repository
public class QuerydslRepositorySupportMy extends QuerydslRepositorySupport {
private final JPAQueryFactory jpaQueryFactory;
public QuerydslRepositorySupportMy(JPAQueryFactory jpaQueryFactory) {
super(QuerydslTest.class);
this.jpaQueryFactory = jpaQueryFactory;
}
public List<QuerydslTest> findByName(String name) {
return jpaQueryFactory
.selectFrom(querydslTest)
.where(querydslTest.name.eq(name))
.fetch();
}
}
3-5. QuerydslController 생성
package com.otrodevym.spring.base.common.Querydsl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
@RequestMapping("/dsl")
public class QuerydslController {
@Autowired
private QuerydslRepository querydslRepository;
@Autowired
private QuerydslRepositorySupportMy querydslRepositorySupportMy;
@GetMapping("name")
public void QuerydslNameTest() {
String name = "test";
querydslRepository.save(new QuerydslTest(name));
List<QuerydslTest> list = querydslRepositorySupportMy.findByName(name);
list.forEach(querydslTest -> System.out.println(querydslTest.getName()));
}
}
3-6. Postman 테스트
3-7. 결과
반응형