QueryDSL이란? + 랜덤 레코드 가져오기 (feat. MySQL)

최미래·2024년 1월 31일
6
post-thumbnail

QueryDSL 이란?

정적 타입을 이용해서 SQL과 같은 쿼리를 생성할 수 있도록 해주는 프레임워크이다.
한마디로 SQL, JPQL 등을 코드로 작성할 수 있도록 해주는 빌더 오픈소스 프레임워크이다.

사용 이유

내가 알아본 JPQL은 이러한 문제점이 있었다.

  • 타입안정성이 떨어진다
  • 직관적인 동적쿼리 작성이 어렵다
  • 쿼리를 여전히 문자열로 입력한다
  • 받아와야 할 쿼리 갯수와 Repository 추가 메서드가 많아진다

등등..

그리고 QueryDSL은 이러한 장점이 있다.
➡️ 쿼리를 문자열로서가 아니라 코드를 통해서 작성하기 때문에 오타가 날 확률이 적어지고, 객체 지향적으로 개발이 가능하다.
➡️ 코드로서 작성하기 때문에 컴파일 단계에서도 오류를 빠르게 발견할 수 있다.

QueryDSL을 사용해서 랜덤한 레코드 가져오기

개요

프로젝트 진행중 회사랑 제품을 랜덤으로 뽑는 기능이 필요하게 되었고 나는 QueryDSL을 적용해 보기로 했다.

Gradle 설정

plugins {
    id 'java'
    id 'org.springframework.boot' version '3.2.2'
    id 'io.spring.dependency-management' version '1.1.4'
    id "com.ewerk.gradle.plugins.querydsl" version "1.0.10"
}

group = 'com.example'
version = '0.0.1-SNAPSHOT'

java {
    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'
    runtimeOnly 'com.mysql:mysql-connector-j'
    annotationProcessor 'org.projectlombok:lombok'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
    testImplementation 'org.springframework.security:spring-security-test'
    implementation 'io.jsonwebtoken:jjwt-api:0.12.3'
    implementation 'io.jsonwebtoken:jjwt-impl:0.12.3'
    implementation 'io.jsonwebtoken:jjwt-jackson:0.12.3'
    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"
}

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

def querydslDir = "$buildDir/generated/querydsl"

querydsl {
    jpa = true
    querydslSourcesDir = querydslDir
}

sourceSets {
    main.java.srcDir querydslDir
}

configurations {
    compileOnly {
        extendsFrom annotationProcessor
    }
    querydsl.extendsFrom compileClasspath
}

compileQuerydsl {
    options.annotationProcessorPath = configurations.querydsl
}

이렇게 Gradle 파일을 세팅한 후, Gradle 탭에서 compileQuerydsl을 "run" 해주니까 자동으로 Q파일들이 생성되었다.

랜덤 레코드 뽑아오는 코드

public List<Company> findListOfCompany() {
    return jpaQueryFactory.selectFrom(qCompany)
            .orderBy(Expressions.numberTemplate(Double.class, "function('rand')").asc())
            .limit(5)
            .fetch();
}

5개씩 리스트로 받아와야하기 때문에 이렇게 작성해 주었다.


후기

사실 개발이 끝난 이후 디자인이 바뀌게 되어 JPQL을 사용하였지만 ㅠ.ㅠ
이번 기회에 QueryDSL을 공부하며 또 한번 성장한거 같다.

더 공부해서 다음 프로젝트에서 동적 쿼리 생성시 꼭 응용 해보아야겠다.

profile
주니어 백엔드 엔지니어, 최미래입니다.

0개의 댓글

관련 채용 정보