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

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

작성한 질문수

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

JPA Exception 핸들링 질문 드립니다

작성

·

245

0

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

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

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

[질문 내용]

안녕하세요 강사님 수업 감사히 듣고 있습니다..

 

jpa 사용하면서 동시성 제어 문제를

비관적락과 + db 트리거를 사용해서

동시에 오더 생성시

저장 -> 채번(비관적락) + 디테일Insert(db트리거 체크) -> JpaSystemException(원인:SQLException db 트리거)

을 발생 시킵니다

 

 

서비스로직 처리시 어플리케이션 에러가 발생하면

처리 히스토리 로그 테이블에

jpa에서 벹어낸 에러 정보( db 트리거에러 메세지) = detailMessage 값을

가져와서 히스토리에 넣고 싶습니다

JpaSystemException

SQLException

detailMessage

 

아래 첨부 이미지와 같이

디버깅모드에 담긴 detailMessage

자바코드로 어떤식으로 가져와야 하는지

모르겠어서 문의 드립니다

 

20220929_jpa_트리거_예외가져오기_01.jpg

답변 1

0

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

강사님 우선 구글링 찾아보니 아래 내용 있어 공유합니다

//아파치 예외 유틸 최상위 에러메세지

ExceptionUtils.getRootCauseMessage

//현재 쓰레드의 소스위치 트레이스

Arrays.toString(Thread.currentThread().getStackTrace())

ExceptionUtils 유틸클래스 메서드를 확인해보겠습니다

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

동희님 스스로 잘 해결하셨습니다^^