스프링 데이터 JPA에 대한 포스팅은 위와 같은 간단한 도메인 모델을 기준으로 한다.
JPA
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
@Repository
public class MemberJpaRepository {
@PersistenceContext
private EntityManager em;
public Member save(Member member) {
em.persist(member);
return member;
}
public void delete(Member member) {
em.remove(member);
}
public List<Member> findAll() {
return em.createQuery("select m from Member m", Member.class)
.getResultList();
}
public Optional<Member> findById(Long id) {
Member member = em.find(Member.class, id);
return Optional.ofNullable(member);
}
public long count() {
return em.createQuery("select count(m) from Member m", Long.class)
.getSingleResult();
}
public Member find(Long id) {
return em.find(Member.class, id);
}
}
빠르게 비교하기 위해 순수 JPA로 이루어진 리포지토리 코드이다.
공통 인터페이스
1
2
public interface MemberRepository extends JpaRepository<Member, Long> {
}
순수 JPA로 구현한 MemberJpaRepository 대신 스프링 데이터 JPA가 제공하는 공통 인터페이스를 사용한다.
- @Repository 애노테이션을 생략 가능하다.
- org.springframework.data.repository.Repository를 구현한 클래스는 스캔 대상
- <> 내부는 Entity, PK 타입으로 이루어져 있다.
스프링 데이터 JPA가 프록시로 가짜 클래스를 만든 후 주입을 해주는 것이다.
- JpaRepository 인터페이스 : 공통 CRUD 제공
- save(S): 새로운 엔티티는 저장, 이미 있는 엔티티는 병합
- delete(T): 엔티티 하나를 삭제함.
- EntityManager.remove() 호출
- findById(ID): 엔티티 하나 조회
- EntityManager.find() 호출
- getOne(ID): 엔티티를 프록시로 조회
- EntityManager.getReference() 호출
- findAll(…): 모든 엔티티 조회. 정렬이나 페이징 조건을 파라미터로 제공할 수 있다.
이와 같이 JPARepository는 대부분의 공통 메서드를 제공해준다.