DeJa
Techvu
DeJa
전체 방문자
51,022
오늘
0
어제
20
  • Techvu (60)
    • DesignPatterns (3)
      • 생성 (0)
      • 구조 (1)
      • 행동 (2)
    • Refactoring (0)
    • DataStructures (0)
    • Algorithms (24)
      • 기본 지식 (12)
      • 문제 풀이 (12)
    • OOP (0)
    • TDD (2)
    • DDD (0)
    • Programming Languages (9)
      • Java (9)
      • Kotlin (0)
    • Spring (1)
    • JPA (7)
    • Web (1)
      • 기본 지식 (1)
      • 실무 경험 (0)
    • CS (12)
      • Network (1)
      • OS (8)
      • DataBase (3)
      • Server (0)
    • Git (1)
    • Conferences (0)

블로그 메뉴

  • 홈
  • 태그
  • 미디어로그
  • 위치로그
  • 방명록

공지사항

  • Study
  • GitHub
  • Medium Blog

인기 글

  • 스키마(Schema)
    2022.01.08
    스키마(Schema)
  • 자바 버전별 역사 및 특징
    2022.01.12
    자바 버전별 역사 및 특징
  • 깃허브 사용 방법
    2021.12.15
    깃허브 사용 방법
  • JPA 는 과연 1차 캐시를 통해서 Repeatable R⋯
    2021.12.27
    JPA 는 과연 1차 캐시를 통해서 Repeatable R⋯
  • 동시성 이슈(Concurrency Issue)
    2022.03.20
    동시성 이슈(Concurrency Issue)

태그

  • 알고리즘
  • CS
  • DATABASE
  • 디자인패턴
  • TDD
  • java
  • JPA
  • OS
  • Spring
  • network
  • web

최근 댓글

  • 글 잘읽고 가요.
    아이폰
  • 컴파일러자체에서 꼬리재귀를 지원하지 않으니 static으로⋯
    aaa
  • 압도적 감사
    ㅇㅇㅇ

최근 글

  • Write a test code right now
    2022.03.24
    Write a test code right now
  • 동시성 이슈(Concurrency Issue)
    2022.03.20
    동시성 이슈(Concurrency Issue)
  • POJO, JavaBean, Entity, VO, DTO
    2022.02.08
    POJO, JavaBean, Entity, VO, DTO
  • TDD with Agile
    2022.02.05
    TDD with Agile
  • Java Stream 기초
    2022.01.23
    Java Stream 기초

티스토리

hELLO · Designed By 정상우.
DeJa

Techvu

JPA 는 과연 1차 캐시를 통해서 Repeatable Read 를 지원할까?
JPA

JPA 는 과연 1차 캐시를 통해서 Repeatable Read 를 지원할까?

2021. 12. 27. 19:19
728x90

JPA 는 과연 1차 캐시를 통해서 Repeatable Read 를 애플리케이션 레벨에서 지원할까 ?

이번 주제는 JPA 는 과연 1차 캐시를 통해서 Repeatable Read 를 애플리케이션 레벨에서 지원하는지에 대해 테스트한 결과를 정리한 내용이다.

Repeatable Read

Repeatable Read 는 트랜잭션 고립 레벨2(Transaction Isolation Level)에 속한다.

  • MySQL InnoDB 에서 기본으로 채택하고 있는 격리 수준
  • 선행 트랜잭션이 읽은 데이터는 트랜잭션이 종료될 때가지 후행 트랜잭션이 갱신하거나 삭제하는 것은 불허함으로써 같은 데이터를 두 번 쿼리했을 때 일관성 있는 결과를 리턴
    • Insert 는 가능
  • Phantom Read 현상은 여전히 발생

위와 같은 특징을 가지고 있다.

테스트하는 데이터베이스는 H2 이며 H2 는 Read Committed 를 기본으로 설정되어있기 때문에, 테스트를 위해서 레벨을 따로 바꿔줄 필요는 없다.

Test

@Getter @Setter
@Entity
public class Member {

    @Id
    @GeneratedValue
    private Long id;
    private String userName;
}
@DisplayName("Repeatable Read Test")
@SpringBootTest
class RepeatableReadTest {

    @Value("${persistence.unitname}")
    private String persistenceUnitName;

    @DisplayName("1차 캐시를 통한 Repeatable Read 를 지원하는지 테스트")
    @Test
    void repeatableReadByCache() throws Exception {
        // given
        EntityManagerFactory emf = Persistence.createEntityManagerFactory(persistenceUnitName);
        insertDummyData(emf);

        // when
        EntityManager em = emf.createEntityManager();
        EntityTransaction tx = em.getTransaction();

        tx.begin(); // 선행 트랜잭션 시작
        Member findMember1 = em.find(Member.class, 1L);
        /**
         * findMember1 : Member 를 데이터베이스에서 조회
         * Member 를 다시 조회하기 전에 H2 데이터 베이스에서 UPDATE 문 실행
         * findMember2 : Member 를 데이터베이스가 아닌 1차 캐시에서 조회
         */
        Member findMember2 = em.find(Member.class, 1L);
        tx.commit(); // 선행 트랜잭션 종료
        em.close();
        emf.close();

        // then
        assertThat(findMember1.getUserName()).isEqualTo(findMember2.getUserName());
    }

    @DisplayName("더미 데이터 삽입")
    private void insertDummyData(EntityManagerFactory emf) {
        EntityManager em = emf.createEntityManager();
        EntityTransaction tx = em.getTransaction();

        tx.begin();

        Member member = new Member();
        member.setUserName("JungHo");
        em.persist(member);
        tx.commit();

        em.close();
    }
}

순서는 다음과 같이 진행했다.

  • 더미 데이터 삽입
  • 선행 트랜잭션 시작
  • Member 를 데이터베이스에서 조회
  • H2 데이터베이스에서 직접 Update 쿼리를 날린다.
    • UPDATE MEMBER SET USERNAME = 'TEST' WHERE ID = 1;
  • Member 를 다시 조회
    • 이때, 데이터베이스가 아닌 1차 캐시를 통해서 데이터가 조회된다.
    • 따라서, USERNAME 이 TEST 가 아닌 JungHo 가 조회된다.
  • 선행 트랜잭션 종료

테스트 결과, JPA 는 1차 캐시를 통해서 데이터베이스가 아닌 애플리케이션 레벨에서 Repeatable Read를 제공하는 것을 알 수있다.

728x90
저작자표시 비영리 동일조건
  • 카카오스토리
  • 트위터
  • 페이스북

'JPA' 카테고리의 다른 글

다양한 연관관계 매핑과 설정에 따른 트레이드 오프  (0) 2021.12.31
테이블과 컬럼에 대한 명세를 엔티티에 자세하게 적는것이 좋은지?  (0) 2021.12.29
AllocationSize 를 통한 성능 최적화  (0) 2021.12.28
기본키 매핑 전략에 따른 INSERT QUERY 실행 시점  (0) 2021.12.28
EntityManager 를 쓰레드간 공유하면 안되는 이유  (0) 2021.12.28
    'JPA' 카테고리의 다른 글
    • 테이블과 컬럼에 대한 명세를 엔티티에 자세하게 적는것이 좋은지?
    • AllocationSize 를 통한 성능 최적화
    • 기본키 매핑 전략에 따른 INSERT QUERY 실행 시점
    • EntityManager 를 쓰레드간 공유하면 안되는 이유
    JPA, Spring
    DeJa
    DeJa
    Tech Blog
    댓글쓰기
    EntityManager 를 쓰레드간 공유하면 안되는 이유
    다음 글
    EntityManager 를 쓰레드간 공유하면 안되는 이유

    티스토리툴바