작성
·
246
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
자바코드로 어떤식으로 가져와야 하는지
모르겠어서 문의 드립니다
답변 1
0
강사님 우선 구글링 찾아보니 아래 내용 있어 공유합니다
//아파치 예외 유틸 최상위 에러메세지
ExceptionUtils.getRootCauseMessage
//현재 쓰레드의 소스위치 트레이스
Arrays.toString(Thread.currentThread().getStackTrace())
ExceptionUtils 유틸클래스 메서드를 확인해보겠습니다
동희님 스스로 잘 해결하셨습니다^^