트랜잭션 격리수준
500
15 asked
안녕하세요 영한님 질문있습니다!
영속성 컨텍스트의 이점 중 하나가
1차 캐시로 REPEATABLE_READ 격리 수준을 애플리케이션 차원에서 제공해준다고 했는데요.
그럼 JPA에서 내부적으로 REPEATABLE_READ 격리수준을 보장하기 위해 락(Lock)이 걸려 있는건가요?
그리고 혹시 추가적으로 어떻게 REPEATABLE READ를 보장해주는 지 알 수 있는지에 대한 자료는 hibernate 공식문서에 가면 있을까요?
Answer 2
1
안녕하세요. 인철님
REPEATABLE_READ라는 격리 수준은 한번 읽은 내용을 동일하게 계속 읽을 수 있다는 뜻입니다. 별도의 락을 사용하는 것은 아니고 영속성 컨텍스트의 개념 덕분에 이것이 자동으로 적용됩니다.
Q: 그리고 혹시 추가적으로 어떻게 REPEATABLE READ를 보장해주는 지 알 수 있는지에 대한 자료는 hibernate 공식문서에 가면 있을까요?
A: https://docs.jboss.org/hibernate/orm/4.3/manual/en-US/html/ch13.html
감사합니다.
0
답변 정말 감사드립니다!!
근데 REPEATABLE READ는 원래 읽기 연산에 공유 락(Shared Lock)을 걸고 트랜젹션을 끝까지 유지하고 쓰기 연산에 배타 락(Exclusive Lock)을 설정하는 개념 아닌가요?
0
REPEATABLE READ의 핵심은 락이라기 보다는 하나의 트랜잭션 안에서 읽은 데이터를 계속 같은 데이터 값으로 읽을 수 있다는 점입니다. 이것을 데이터베이스에 따라서 어떻게 구현하는가가 달라집니다. 생각하신 것 처럼 락으로 주로 구현하겠지요?
그런데 JPA는 1차 캐시가 있기 때문에 락을 걸지 않고도 1차 캐시 덕분에 REPEATABLE READ의 효과를 볼 수 있습니다.
감사합니다.
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
28
2
inheritance startegy 선택시 고려사항
0
22
1
Entity 동등성 비교
0
21
1
실무 조언 관련 질문입니다.
0
47
1
H2데이터베이스 파일 생성
0
56
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
53
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
54
1
JPQL 메소드와 락
0
55
1
Delivery @OneToOne
0
60
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
94
2
UnsupportedOperationException 발생
0
86
3
H2 Database 연결이 안됩니다.
0
95
2
연관관계 매핑 질문드립니다.
0
85
2
h2데이터베이스 실행오류
0
108
2
persistence.xml
0
108
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
80
1
영속성 컨텍스트
0
66
1
JPA 프록시
0
96
1
Native Query와 MyBatis
0
70
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
87
1
임베디드 타입 예시 코드 관련 질문
0
115
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
95
3
인텔리제이 패키지 커서 단축키 질문
0
108
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
145
1

