inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

트랜잭션 AOP 주의 사항 - 프록시 내부 호출2

saveAll() 내부에 save()도 내부호출인 건가요?

108

김민재

작성한 질문수 10

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]

그 트랜잭션 전파에 대해서 공부하다가 궁금증이 생겼는데

JpaRepository의 구현체인 SimpleJpaRepository에서 saveAll() 메서드도 내부에서 save()메서드를 호출하잖아요?

그러면 이때 호출되는 save()메서드도 내부호출이니까 @Transactional이 적용이 안되는 건가요?

풀어서 말하자면

  1. saveAll()이 호출될때 @Transactional로 트랜잭션이 시작됨

  2. saveAll() 내부에서 save() 메서드를 호출하지만 내부호출이므로 트랜잭션 전파가 아닌 그냥 save()메서드가 호출됨

  3. 결과적으로는 트랜잭션이 saveAll() 호출시 하나만 시작되고 save()들은 내부호출이므로 트랜잭션 전파를 받는것이아닌 saveAll()이 호출될때 시작된 트랜잭션을 따름

위와 같이 이해하는게 맞을까요?

 

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

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 김민재님.

spring의 트랜잭션 AOP에서 내부호출에 대한 부분은 많은 분들이 이해하는 데 혼란을 겪을 수 있는 주제입니다. 말씀하신 상황에 대해 설명드리겠습니다.

Spring AOP와 내부 호출

  1. saveAll()의 트랜잭션 시작: @Transactional이 메서드에 적용되면, 스프링은 AOP 프록시를 사용하여 메서드 호출 이전에 트랜잭션을 시작합니다. saveAll()이 메서드 시작 시에 트랜잭션을 시작하게 됩니다.

  2. 내부에서 save() 호출: saveAll() 메서드 내부에서 save() 메서드를 호출하지만, 이는 같은 클래스 내의 호출입니다. 여기서 @Transactional의 트랜잭션 전파가 ‘없다는’ 표현은 약간 오해일 수 있습니다. 실제로, 트랜잭션은 이미 시작되었으므로, 내부 호출된 메서드인 save()는 이미 열린 트랜잭션에 참여하게 됩니다.

  3. 결과적으로 트랜잭션 흐름: saveAll()에서 트랜잭션을 시작하면, 이후 save() 호출은 이 트랜잭션 컨텍스트 내에서 수행됩니다. 즉, 이미 열린 트랜잭션을 계속 따르게 됩니다.

말씀하신 이해는 대체로 올바릅니다. saveAll()에서의 트랜잭션은 save() 내부 호출에서 분리되지 않고 이미 시작한 트랜잭션을 그대로 따르게 됩니다. 스프링에서는 이미 생성된 트랜잭션 내에서 트랜잭션 전파를 처리하므로, 내부의 save()는 트랜잭션 전파의 형태로 동작한다고 볼 수 있습니다.

혹시 트랜잭션 전파에 대한 좀 더 깊이 있는 이해가 필요하시다면, 아래 링크도 참고하시길 바랍니다:
- 트랜잭션 전파 - 기본 이해
- 프록시와 내부 메서드 호출 관련 이해

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

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