먼저 순수 JPA 기반 리포지토리 만들어 보겠습니다. 그리고 스프링 데이터 JPA 공통 인터페이스 소개하면서 스프링 데이터 JPA 로 변경하는 것을 보여드리겠습니다.

결국 스프링 데이터 JPA 도 JPA 를 편하게 사용하기 위해 만들어진 기술이기 때문이죠.

순수 JPA 기반 리포지토리 만들기

기본 CRUD 를 추가하겠습니다.

@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(); //...1
    }

    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(); //...2
    }

    public Member find(Long id) {
        return em.find(Member.class, id);
    }

}

  1. getSingleResult()
  2. getResultList()
@Repository
public class TeamJpaRepository {

    @PersistenceContext
    private EntityManager em;

    public Team save(Team team) {
        em.persist(team);
        return team;
    }

    public void delete(Team team) {
        em.remove(team);
    }

    public List<Team> findAll() {
        return em.createQuery("select t from Team t", Team.class)
                .getResultList();
    }

    public Optional<Team> findById(Long id) {
        Team team = em.find(Team.class, id);
        return Optional.ofNullable(team);
    }

    public long count() {
        return em.createQuery("select count(t) from Team t", Long.class)
                .getSingleResult();
    }

}