먼저 순수 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);
}
}
@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();
}
}