• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

spring Exception REQUIRES_NEW 질문 드립니다

22.09.30 08:13 작성 조회수 111

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

김동희님의 프로필

김동희

질문자

2022.10.04

감사합니다. 수고하세요