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

주아아빠님의 프로필 이미지

작성한 질문수

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

spring Exception REQUIRES_NEW 질문 드립니다

작성

·

164

0

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

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

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

[질문 내용]
강사님 덕분에 좋은 수업 잘 듣고 있습니다

운영하는 플랫폼 api 수신 처리 로직 구현중

구현하고 싶은 부분이 마음대로 안되어서

여쭤봅니다

//█====

for Loop

//█====서비스로직 01

@Transactional

원본 호출 메서드

UnexpectedRollbackException

//█====서비스 로직 02

@Transactional(propagation=Propagation.REQUIRES_NEW)

전파옵션 REQUIRES_NEW

상세 메서드 분리

SQLException db 트리거 에러메세지(=>RuntimeException)

 

최초 for Loop 에서

각 Loop 레코드(서비스로직 01) 마다

상세메서드(서비스로직 02) 전파옵션 REQUIRES_NEW 메서드에서

발생한 Exception 원인을 상위로 던지고 싶어서

Map 담아서 리턴을 해보더라도 테스트 해보니

 

원래는 서비스로직 02 에서 발생한

SQLException db 트리거 에러메세지(=>RuntimeException)

이지만, 스프링이 감싼 AOP 때문인지

상위(서비스로직 01 )쪽에서 map으로 받는 Exception은

org.springframework.transaction.UnexpectedRollbackException

로 변환되어서 넘어옵니다

 

오리지날 발생한(서비스 로직 02) Exception 원인

SQLException db 트리거 에러메세지(=>RuntimeException) 을

상위(서비스로직 01) 으로 담아서 받아 올 수 있는 방법이 혹시 있을까 질문 드립니다

 

답변 2

1

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 김동희님

죄송하지만 질문 안내에 있는 것 처럼 강의 학습에 관련된 질문을 올려주시길 부탁드립니다.

저도 마음으로는 도움을 드리고 싶지만, 하루에도 수 많은 분들이 질문을 올려주십니다. 그래서 강의 학습과 관련된 질문에 초점을 맞추는 것이 맞다 생각합니다. 다시한번 이해를 부탁드립니다.

 

0

주아아빠님의 프로필 이미지
주아아빠
질문자

감사합니다. 수고하세요