Java Persistence API (JPA)는 Java 개발자가 관계형 데이터베이스에서 자바 객체를 저장, 수정, 삭제, 조회할 수 있게 도와주는 인터페이스입니다. 리포지토리는 기본적으로 CRUD(Create, Read, Update, Delete)를 수행할 수 있어야 합니다.
저장 JPA를 사용하면 자바 객체를 관계형 데이터베이스에 저장할 수 있습니다. EntityManager의 persist 메소드를 이용하면 간단하게 저장할 수 있습니다.
변경 JPA는 변경 감지라는 기능을 제공합니다. 트랜잭션 안에서 엔티티를 조회한 후 데이터를 변경하면, 트랜잭션이 종료되는 시점에 변경 감지 기능이 작동합니다. 변경된 엔티티를 감지하고 UPDATE SQL을 자동으로 실행합니다.
삭제 엔티티를 삭제하는 것도 간단합니다. EntityManager의 remove 메소드를 사용하면 됩니다.
전체 조회 EntityManager의 createQuery 메소드를 사용하여 JPQL을 이용하면 전체 엔티티를 조회할 수 있습니다.
단건 조회 find 메소드를 이용하면 특정 엔티티를 조회할 수 있습니다.
카운트 JPQL의 COUNT 함수를 이용하면 저장되어 있는 엔티티의 개수를 세는 것도 가능합니다.
val deletedCount = memberJpaRepository.count() assertThat(deletedCount).isEqualTo(0) }
}
공통 인터페이스 설정
JavaConfig 설정- 스프링 부트 사용시 생략 가능
1 2 3
@Configuration @EnableJpaRepositories(basePackages = "jpabook.jpashop.repository") class AppConfig {}
@SpringBootApplication 애노테이션 위치를 기준으로 해당 패키지와 하위 패키지를 자동으로 스캔하므로, 따로 위치를 지정하지 않아도 됩니다. org.springframework.data.repository.Repository 인터페이스를 구현한 클래스를 자동으로 스캔하고 등록하기 때문입니다.
예를 들어, MemberRepository 인터페이스는 구현 클래스 없이도 동작합니다. 인터페이스의 구체적인 클래스를 확인해보면, com.sun.proxy.$ProxyXXX와 같은 프록시 클래스라는 것을 확인할 수 있습니다.
1
memberRepository.getClass() // class com.sun.proxy.$ProxyXXX
또한, @Repository 애노테이션을 생략할 수 있습니다. 이는 스프링 데이터 JPA가 자동으로 컴포넌트 스캔을 처리하고, JPA 예외를 스프링 프레임워크의 데이터 액세스 예외로 변환하기 때문입니다. 이렇게 스프링 데이터 JPA는 개발자가 중복된 CRUD 코드를 작성하는 것을 피하게 해주고, 개발 과정을 간소화하며 생산성을 향상시키는 데 크게 기여합니다.
공통 인터페이스 적용
기존에 순수 JPA로 구현했던 MemberJpaRepository를 스프링 데이터 JPA 기반의 MemberRepository로 대체할 예정입니다. 먼저 MemberRepository 인터페이스를 살펴보면, JpaRepository<Member, Long>를 상속받고 있음을 확인할 수 있습니다. 이를 통해 우리는 JPA의 기본적인 CRUD 기능들을 간편하게 사용할 수 있게 됩니다.