강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

강동훈님의 프로필 이미지
강동훈

작성한 질문수

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

회원 서비스 개발

@Transactional에서 Isolation level 설정 질문입니다

작성

·

710

0

@Transactional 어노테이션으로 트랜잭션을 설정할 때 옵션으로 Isolation level을 지정할 수 있는것에 대해 궁금한 게 있습니다. 보통 Transaction의 격리 수준은 DBMS에서 설정하여 동작하는 것으로 알고 있는데, 스프링에서 직접 Isolation Level을 지정한다는 것은 어떤 것을 의미하나요?? 스프링과 연동중인 DB의 Isolation level을 스프링이 직접 지정하는건지, 아니면 DBMS에서 트랜잭션 로직과 별개로 스프링에서 트랜잭션 매니저가 트랜잭션을 수행하는 자바 코드가 동작하는 트랜잭션 로직의 Isolation Level을 지정하는 건지 궁금합니다!

답변 1

0

안녕하세요, 강동훈님:)

.

Spring의 transactional 애노테이션의 isolation level을 지정하게 되면 현재 Datasource로 사용하고 있는 데이터베이스의 isolation level을 변경합니다.

.

참고

https://jeong-pro.tistory.com/228

https://docs.oracle.com/javase/tutorial/jdbc/basics/transactions.html

---

추가 답변

@Transactional 애노테이션이 붙었을 때 Spring이 내부적으로 어떻게 처리하는지 조금 더 찾아봤습니다.

@Transactional 애노테이션을 감지하는 Transaction Interceptor가 있습니다.

Transaction Interceptor는 PlatformTransactionManager를,

PlatformTransactionManager는 EntityMnager에게 트랜잭션 시작을 요청합니다.

이때 내부적으로 더 파고들면 JDBC 구현체가 실제 DB의 connection을 가져옵니다.

그리고 가져온 connection에 필요한 설정을 적용합니다. 예를들어 isolation level 같은 것을 적용할 수 있습니다. (ex. connection.setAutoCommit(false); // 트랜잭션 시작)

.

따라서 @Transactional을 통해 isolation level을 지정하면 내부적으로는 jdbc 구현체를 통해 db의 connection에 isolation level을 지정하게 됩니다.

강동훈님의 프로필 이미지
강동훈
질문자

자세하고 친절한 답변 감사합니다!

강동훈님의 프로필 이미지
강동훈

작성한 질문수

질문하기