[Spring Boot2][3] 5. 스프링 데이터 JPA & QueryDSL
🏷 스프링 데이터 JPA
스프링 데이터 JPA는 JPA를 사용할 때 지루하게 반복하는 코드를 자동화 해준다.
이미 라이브러리는 포함되어 있고, 기존의 MemberRepository 를 스프링 데이터 JPA로 변경해보자!
1️⃣ MemberRepository 인터페이스 생성
package jpabook.jpashop.repository;
import jpabook.jpashop.domain.Member;
import org.springframework.data.jpa.repository.JpaRepository;
import java.util.List;
public interface MemberRepository extends JpaRepository<Member, Long> {
        List<Member> findByName(String name);
}
2️⃣ MemberService 수정
findOne() ➡️ findById()로 모두 변경하자.
스프링 데이터 JPA는 JpaRepository 라는 인터페이스를 제공하는데, 여기에 기본적인 CRUD 기능이 모두 제공된다!
findByName 처럼 일반화 하기 어려운 기능도 메소드 이름으로 정확한 JPQL 쿼리를 실행한다.
➡️ select m from Member m where m.name = :name
개발자는 인터페이스만 만들면 된다👍🏻 구현체는 스프링 데이터 JPA가 애플리케이션 실행시점에 주입해준다!
📌 참고
스프링 데이터 JPA는 JPA를 사용해서 이런 기능을 제공할 뿐이다.
결국 JPA 자체를 잘 이해하는 것이 가장 중요하다!
🏷 QueryDSL
실무에서는 조건에 따라서 실행되는 쿼리가 달라지는 동적 쿼리를 많이 사용한다.
주문 내역 검색으로 돌아가보고, 이 예제를 Querydsl로 바꾸어 보자!
1️⃣ 주문내역 검색 수정
public List<Order> findAll(OrderSearch orderSearch) {
	QOrder order = QOrder.order;
    QMember member = QMember.member;
    
    return query
    	.select(order)
    	.from(order)
        .join(order.member, member)
        .where(statusEq(orderSearch.getOrderStatus()),
        nameLike(orderSearch.getMemberName()))
        .limit(1000)
        .fetch();
}
private BooleanExpression statusEq(OrderStatus statusCond) {
    if (statusCond == null) {
        return null;
    }
    return order.status.eq(statusCond);
}
private BooleanExpression nameLike(String nameCond) {
    if (!StringUtils.hasText(nameCond)) {
        return null;
    }
    return member.name.like(nameCond);
}
2️⃣ build.gradle 수정
// querydsl 추가 
buildscript {
  dependencies {
      classpath("gradle.plugin.com.ewerk.gradle.plugins:querydsl-
plugin:1.0.10")
  }
dependencies {
.
.
// querydsl 추가
implementation 'com.querydsl:querydsl-jpa' 
// querydsl 추가
implementation 'com.querydsl:querydsl-apt'
}
//querydsl 추가
//def querydslDir = 'src/main/generated'
def querydslDir = "$buildDir/generated/querydsl"
Querydsl은 SQL(JPQL)과 모양이 유사하면서 자바 코드로 동적 쿼리를 편리하게 생성할 수 있다!
실무에서는 복잡한 동적 쿼리를 많이 사용하게 되는데, 이때 Querydsl을 사용하면 높은 개발 생산성을 얻으면서 동시에 쿼리 오류를 컴파일 시점에 빠르게 잡을 수 있다.
꼭 동적 쿼리가 아니라 정적 쿼리인 경우에도 다음과 같은 이유로 Querydsl을 사용하는 것이 좋다.
- 직관적인 문법
 - 컴파일 시점에 빠른 문법 오류 발견
 - 코드 자동완성
 - 코드 재사용
 - JPQL new 명령어와는 비교가 안될 정도로 깔끔한 DTO 조회를 지원
 
Querydsl은 JPQL을 코드로 만드는 빌더 역할을 할 뿐이다.
따라서 JPQL을 잘 이해하면 금방 배울 수 있다!!!!
Querydsl은 JPA로 애플리케이션을 개발 할 때 선택이 아닌 필수이다👍🏻
📌 Querydsl에 대한 내용은 분량이 상당해서, 별도의 강의로 진행된다!
Author And Source
이 문제에 관하여([Spring Boot2][3] 5. 스프링 데이터 JPA & QueryDSL), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@sorzzzzy/Spring-Boot23-5.-스프링-데이터-JPA-QueryDSL저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
                                
                                
                                
                                
                                
                                우수한 개발자 콘텐츠 발견에 전념
                                (Collection and Share based on the CC Protocol.)