-
카테고리
-
세부 분야
백엔드
-
해결 여부
미해결
한 트랜잭션내 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이 적용되는걸까요?
어느부분을 참조하면 좋을지 조언부탁드립니다.
감사합니다.
답변을 작성해보세요.
0
김영한
지식공유자2022.05.22
안녕하세요. jandeungun님
1. 트랜잭션 이라는 것은 작업을 하나의 원자적인 단위로 만드는 작업입니다.
따라서 한 트랜잭션 안에서 2개의 entity가 모두 저장되던가 모두 실패해야 합니다.
이 경우 트랜잭션을 각각 따로 분리해서 사용하셔야 합니다.
트랜잭션에 대한 자세한 내용은 스프링 DB 1편 강의를 참고해주세요.
2. Q: JPA는 @transactional 없이도 rollback이 적용되는걸까요?
-> JPA의 모든 데이터 변경은 트랜잭션 안에서 이루어져야 합니다. 트랜잭션이 없으면 데이터 변경 자체가 불가능합니다.
감사합니다.
답변 1