반응형
1. 스프링 데이터 JPA 소개
스프링 데이터 JPA
- 스프링 프레임워크에서 JPA를 편리하게 사용할 수 있도록 지원하는 프로젝트
- 데이터 접근 계층(DAO)을 개발할 때 구현 클래스 없이 인터페이스만 작성해도 개발을 완료(지루하게 반복되는 CRUD 문제를 세련된 방법으로 해결, 인터페이스만 작성하면 실행시점에 스프링 데이터 JPA가 구현 객체를 동적으로 생성해서 주입)
public interface MemberRepository extends JpaRepository<Member, Long>{
Member findByUsername(String username);
}
public interface ItemRepository extends JpaRepository<Item, Long>{
}
2. 공통 인터페이스 기능
스프링 데이터 JPA는 간단한 CRUD 기능을 공통으로 처리하는 JpaRepository 인터페이스를 제공한다.
주요 메서드
save(S) 새로운 엔티티를 저장하고, 이미 있는 엔티티는 수정
delete(T) 엔티티 하나를 삭제. 내부에서 EntityManager.remove() 호출
findOne(ID) 엔티티 하나를 조회. 내부에서 EntityManager.find() 호출
getOne(ID) 엔티티를 프록시에서 조회. 내부에서 EntityManager.getReference() 호출
findAll 모든 엔티티 조회. 정렬이나 페이징 조건 파라미터를 제공할 수 있다.
save(S) 식별자가 없으면 새로운 엔티티로 판단하여, EntityManager.persist() 호출
식별자값이 있으면 이미 있는 엔티티로 판단해서 EntityManager.merge()를 호출
3. 쿼리 메소드 기능
스프링 데이터 JPA가 제공하는 마법같은 기능
- 메소드 이름만으로 쿼리를 생성하는 기능
- 인터페이스 메소드만 선언하면 메소드 이름으로 JPQL 쿼리를 생성해서 실행
스프링 데이터 JPA가 제공하는 쿼리 메소드 기능 3가지
- 메소드 이름으로 쿼리 생성
- 메소드 이름으로 JPA NamedQuery 호출
- @Query 어노테이션을 사용해서 Repository 인터페이스에 쿼리 직접 정의
3-1. 메소드 이름으로 쿼리 작성
정해진 규칙에 따라 메소드 이름을 지어야한다.
public interface MemberRepository extends JpaRepository<Member, Long>{
List<Member> findByEmailAndName(String email, String name);
}
http://docs.spring.io/spring-data/jpa/docs/1.3.0.RELEASE/reference/html/jpa.repositories.html
3-2. JPA NamedQuery (정적쿼리)
Named 네이티브 쿼리를 지원함
// NamedQuery 설정
@Entity
@NamedQuery (
name ="Member.findByUsername",
query = "select m from Member m where m.username = :username")
public class Member{
...
}
// NamedQuery 사용시
List<Member> resultList =
em.createNamedQuery("Member.findByUsername", Member.class).setParameter("username", "corn").getResultList();
스프링 데이터 JPA로 Named 쿼리 호출
public interface MemberRepository extends JpaRepository<Member, Long>{
List<Member> findByUsername(@Param("username") String username);
}
3-3. @Query, Repository 메소드에 쿼리 정의
public interface MemberRepository extends JpaRepository<Member, Long>{
@Query("select m from Member m where m.email = ?1 and m.name = ?2")
List<Member> findByEmailAndName(String email, String name);
}
=> 파라미터는 위치 기반, 이름 기반 둘다 지원한다.
파라미터바인딩 참고
반응형
'프로그래밍 노트 > JPA' 카테고리의 다른 글
[JPA] 영속성관리_2 (영속성 컨텍스트 특징, 조회, 수정, 삭제) (0) | 2019.09.16 |
---|---|
[JPA] 영속성 관리_1 (EntityManager, EntityManagerFactory, PersistContext) (0) | 2019.09.03 |
[JPA] 객체지향 쿼리 QueryDSL (0) | 2019.08.26 |
[JPA] JPQL 문법, 내용정리 (0) | 2019.08.21 |
[JPA] JPQL이란? (0) | 2019.08.18 |