환경설정

OneTwoThree·2023년 8월 10일
0

실전querydsl

목록 보기
1/6

출처


Querydsl 설정, 검증

buildscript{
	ext {
		queryDslVersion = "5.0.0"
	}
}

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

group = 'study'
version = '0.0.1-SNAPSHOT'

java {
	sourceCompatibility = '11'
}

configurations {
	compileOnly {
		extendsFrom annotationProcessor
	}
}

repositories {
	mavenCentral()
}

dependencies {
	implementation 'org.springframework.boot:spring-boot-starter-data-jpa'
	implementation 'org.springframework.boot:spring-boot-starter-web'

	//querydsl 추가
	implementation "com.querydsl:querydsl-jpa:${queryDslVersion}"
	annotationProcessor "com.querydsl:querydsl-apt:${queryDslVersion}"

	compileOnly 'org.projectlombok:lombok'
	runtimeOnly 'com.h2database:h2'
	annotationProcessor 'org.projectlombok:lombok'
	testImplementation 'org.springframework.boot:spring-boot-starter-test'
}

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

//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
}
//querydsl 추가 끝

build.gradle에 위와 같이 추가해준다.

querydsl은 qtype을 뽑아내고 그걸 가지고 쿼리를 한다

gradle > tasks > other > compileQuerydsl 더블클릭해서 qtype을 만든다.

def querydslDir = "$buildDir/generated/querydsl" build.gradle에서 지정한 경로에 Qtype이 생긴 것을 확인할 수 있다.

querydsl이 Hello 엔티티를 보고 QHello 엔티티를 만들어준 것이다.
이렇게 만들어진 코드를 가지고 쿼리를 짜게 된다.

생성된 q파일은 git으로 관리하면 안된다.
세부 내용이 generated 될 때마다 달라질 수 있기 때문이다.
gitignore 해줘야 하는데, 애초에 build 폴더 안에 있기 때문에 git에 안올라간다.

@SpringBootTest
@Transactional
class QuerydslApplicationTests {

	@Autowired
	EntityManager em;
	@Test
	void contextLoads() {
		Hello hello = new Hello();
		em.persist(hello);

		JPAQueryFactory query = new JPAQueryFactory(em);
		QHello qHello = QHello.hello;

		Hello result = query
				.selectFrom(qHello)
				.fetchOne();

		assertThat(result).isEqualTo(hello);
		assertThat(result.getId()).isEqualTo(hello.getId());
	}

}

querydsl을 사용할 때 쿼리 관련된 것은 qtype을 사용해야 한다.

스프링부트 설정

spring:
  datasource:
    url: jdbc:h2:tcp://localhost/~/querydsl
    username: sa
    password:
    driver-class-name: org.h2.Driver

  jpa:
    hibernate:
      ddl-auto: create
  properties:
     hibernate:
#      show_sql: true
      format_sql: true
logging.level:
  org.hibernate.SQL: debug
# org.hibernate.type: trace

application.yml 파일을 만들어서 설정해준다.

	//sql 쿼리 파라미터 로그 남기기
	implementation 'com.github.gavlyukovskiy:p6spy-spring-boot-starter:1.5.8'

build.gradle에 라이브러리를 추가해서 sql 쿼리 파라미터를 로그로 남기도록 해준다.
이러한 기능은 개발 단계에서는 마음껏 사용해도 되지만 성능이 중요한 운영 단계에서는 고민해보고 써야 한다.

0개의 댓글