inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 2편 - 데이터 접근 활용 기술

트랜잭션 옵션 소개

트랜잭션 readonly 거는 이유

1040

플하

작성한 질문수 60

0

@Slf4j
static class BasicService {

    @Transactional
    public void tx1() {
    }

    @Transactional(readOnly = true)
    public void tx2() {
    }
}

만약에 이렇게 코드를 만드는데 tx2에서 트랜잭션을 readonly를 언제 보통 거는걸까요?

tx2에 메소드에서 어차피 @Transactional(readOnly) 를 거나 안거나 성능은 별차이가 없는걸까요?

두번째는 어차피 수정 삭제도아니고 조회인데 굳이 트랜잭션을@Transactional(readOnly = true) 거는 이유는 어떤경우가 있나요? 조회를 할때도 트랜잭션이 필요할때가 있어요?

 

spring mvc jpa querydsl spring-data-mybatis spring-jpa

답변 1

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

@Transactional(readOnly = true)를 사용하는 이유는 다음과 같습니다:

  1. 성능 최적화: readOnly 플래그는 읽기 전용으로 설정 될 때 JDBC 드라이버와 JPA 프로바이더에 힌트로 전달됩니다. 예를 들어, Hibernate 사용 시 readOnly로 설정하면 flush 모드를 NEVER로 설정하여 엔티티의 변경사항을 확인하는 단계를 건너뛰게 합니다. 이는 큰 오브젝트 트리에 대한 성능을 눈에 띄게 향상시킬 수 있습니다.

  2. 커넥션 풀에 대한 부담 감소: 트랜잭션이 없는 경우, Spring Data JDBC는 서로 다른 커넥션에서 쿼리를 실행할 수 있는데, 이는 커넥션 풀에 많은 부담을 주고, 여러 메소드가 새 커넥션을 요청하면서 하나를 유지할 때 데드락을 유발할 수도 있습니다.

  3. 명시적 표현: readOnly를 명시적으로 선언함으로써 해당 메소드가 데이터를 변경하지 않고, 오직 읽기만을 수행함을 분명히 할 수 있습니다.

따라서, @Transactional(readOnly = true)는 수정 및 삭제가 아닌 조회 기능을 수행할 때 트랜잭션의 범위를 명확히 하고, 성능 최적화를 위해 사용됩니다. 성능에 차이가 없다고 말할 수 없으며, 특히 대규모 데이터를 다룰 때는 @Transactional(readOnly = true) 설정의 이점이 부각될 수 있습니다.

참고 자료로 Spring Data JDBC 및 Spring Data JPA의 Reference Documentation에서 관련 내용을 확인하실 수 있습니다:

Spring Data JDBC: https://docs.spring.io/spring-data/jdbc/docs/current/reference/html/#jdbc.transaction.query-methods
Spring Data JPA: https://docs.spring.io/spring-data/jpa/docs/current/reference/html/#transactional-query-methods

리어스리님, 추가적인 질문이 있으시면 도와드리겠습니다!

RepositoryTest의 패키지 위치가 domain인 이유

0

29

2

REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!

0

29

1

update()에 사용하는 setter 질문드립니다.

0

47

1

SQL 중심적 개발의 문제점에 대한 질문

0

72

1

혹시 Containing 을 안쓰신 이유가 있을까요?

0

83

2

[공유] 스프링부트 4.x 버전 mybatis 연동

0

173

1

@repository 어노테이션

0

89

3

ItemService

0

58

1

논리 커밋, 물리 커밋 질문드립니다.

0

54

1

내부 트랜잭션 커밋은 필수인가요?

0

57

1

프록시 커넥션 객체를 반환할 때 생성하는건가요?

0

54

1

Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)

2

178

2

JPQL 대신 네이티브 쿼리를 사용해야 하는 경우

0

77

1

@EventListener(ApplicationReadyEvent.class) 관련

0

88

1

트랜잭션 동기화 매니저와 데이터 소스

0

76

1

DB 관련 강의 개설 계획은 없으신건가요?

0

133

2

물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요

0

94

1

스프링 3 버전 이상 rollbackFor 변경된듯요

1

112

1

트랜잭션 전파 질문.

0

87

1

프로젝트 오픈 에러

0

126

1

외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다

0

83

2

같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환

0

72

1

h2 인메모리 테스트중 예약어 충돌날 경우 대처방법

0

102

1

커스텀aop와 트랜잭션을 같이 사용할때 우선순위에 관한 질문

0

98

2