작성
·
342
1
안녕하세요 영한님, 또 질문을 드리게되네요..ㅠ
트랜잭션 전파전략을 런타임에 변경할 수 있나요?
강의에서 설명해주신 MemberService에서 LogRepository에서 예외가 발생하더라도 정상 커밋 수행되도록 하기위해 LogRepository에 REQURIED_NEW로 트랜잭션 전파 레벨을 설정하셨는데요.
만약, 우리가 만든 LogRepository가 MemberService가 아닌 주문 서비스, 결제 서비스 등 여러 서비스 클래스에서 범용적으로 사용할 수 있는 LogRepository라고 가정했을 때, 주문 서비스에서는 LogRepository의 save 메소드를 REQUIRED (디폴트) 범위로 설정하고 싶다고하면...방법이 있을까요?
이러한 가정을 만족하려면 LogRepository를 사용하는 서비스 클래스들이 동적으로 LogRepository의 save메소드의 propagation을 지정해줘야할 것 같은데...이러한 기능은 없을까요?
이러한 기능이 없다면, LogRepository는 똑같은 기능을 하는REQUIRED와 REQUIRED_NEW 을 갖는 메소드 2개를 구현하고 LogRepository 사용하는 서비스 클래스들이 상황에 맞는 메소드를 호출하는 방법밖에 없는게 맞을까요?
추가) 강의 끝까지 들어보니 퍼사드를 적용해서 해결할 수 있겠네요..
답변 1
0
안녕하세요. 이화평님
애노테이션 기반의 선언적 트랜잭션 사용 기법에서는 트랜잭션 전파 방법이 하드코딩 되기 때문에, 실시간으로 같은 코드에서 트랜잭션 전파 전략을 변경할 수 없습니다.
프로그래밍 방식을 사용하면 동적으로 변경이 가능합니다. (물론 너무 복잡해지겠지요?)
감사합니다.