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가지

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

  1. 메소드 이름으로 쿼리 생성
  2. 메소드 이름으로 JPA NamedQuery 호출
  3. @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);
}

=> 파라미터는 위치 기반, 이름 기반 둘다 지원한다.

파라미터바인딩 참고

 

[출처] https://cornswrold.tistory.com/336

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
57 [java, spring] Spring에서 request와 response를 JSON format 으로 한번에 로깅하기 file 졸리운_곰 2021.06.18 178
56 [Spring Boot] 2) Springboot OncePerRequestFilter 와 GenericFilterBean의 차이 file 졸리운_곰 2021.06.18 21
55 [Spring boot] [Spring boot] Spring Boot servlet filter 사용하기 졸리운_곰 2021.06.18 17
54 [SpringBoot] Filter(필터) OncePerRequestFilter간단히 사용하기 file 졸리운_곰 2021.06.18 65
53 [Spring boot] Spring boot 에서 Filter 사용하기 졸리운_곰 2021.06.18 18
52 [Spring Boot] 스프링 부트에 필터를 '조심해서' 사용하는 두 가지 방법 졸리운_곰 2021.06.18 140
51 [스프링 배치] java Spring Batch 졸리운_곰 2020.12.16 77
50 MyBatisPagingItemReader.java 졸리운_곰 2020.11.07 82
» [JPA] 스프링 데이터 JPA 소개 file 졸리운_곰 2020.11.07 23
48 Spring Batch Example 3 - 청크 지향 프로세싱 file 졸리운_곰 2020.10.24 51
47 Spring Batch Example 2 - 간단한 Job만들기 file 졸리운_곰 2020.10.24 15
46 Spring Batch Example 1 - Spring Batch란? file 졸리운_곰 2020.10.24 55
45 [spring batch] Spring batch Job 설정과 실행하기 file 졸리운_곰 2020.10.24 24
44 public class MyBatisPagingItemReader<T> extends AbstractPagingItemReader<T> { 졸리운_곰 2020.10.23 97
43 public class MyBatisBatchItemWriter<T> implements ItemWriter<T>, InitializingBean { 졸리운_곰 2020.10.23 119
42 MyBatisPagingItemReader, MyBatisPagingItemWriter 졸리운_곰 2020.10.23 208
41 [spring batch] 처음 해보는 Spring batch, Tasklet 작성하기 file 졸리운_곰 2020.10.18 15
40 Spring Boot - Properties 사용법 정리 졸리운_곰 2020.10.15 94
39 spring 설정 xml과 소스코드에서 properties 사용하기 졸리운_곰 2020.10.15 14
38 Spring Batch 간단 정리 Sprong Batch 기초를 알아보자 file 졸리운_곰 2020.10.13 47
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED