• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

한 트랜잭션내 DB오류 발생시 예외처리

22.05.19 17:00 작성 조회수 371

1

[질문 내용]
안녕하세요. 강의 잘듣고있습니다.
 
[상황]
1.일대다 양방향 관계인 A,B를 저장하려고 합니다.
2.B(다) entity insert시 오류가 발생했습니다. ( 컬럼 크기 보다 큰 데이터 입력)
3.A(일)는 B 기록에 대한 로그성 테이블입니다.
4.@Transactional 처리 없음
5.A에 오류기록이 저장되지않습니다.
(exception catch 실패, finally에서 persist 작업시 무반응)
 
[문의]
1.한 트랜잭션 안에서 2개의 entity 저장시
B entity 작업에 오류 발생해도 A entity 작업은 rollback이 안되었으면 합니다.
2. JPA는 @transactional 없이도 rollback이 적용되는걸까요?
 
 
어느부분을 참조하면 좋을지 조언부탁드립니다.
감사합니다.
 
 
 
 
 

답변 1

답변을 작성해보세요.

0

안녕하세요. jandeungun님

1. 트랜잭션 이라는 것은 작업을 하나의 원자적인 단위로 만드는 작업입니다.

따라서 한 트랜잭션 안에서 2개의 entity가 모두 저장되던가 모두 실패해야 합니다.

이 경우 트랜잭션을 각각 따로 분리해서 사용하셔야 합니다.

트랜잭션에 대한 자세한 내용은 스프링 DB 1편 강의를 참고해주세요.

2. Q: JPA는 @transactional 없이도 rollback이 적용되는걸까요?

-> JPA의 모든 데이터 변경은 트랜잭션 안에서 이루어져야 합니다. 트랜잭션이 없으면 데이터 변경 자체가 불가능합니다.

감사합니다.