一、转账业务追加日志分析
实现任意两个账户间转账操作,并对每次转账操作在数据库进行留痕
即:A账户减钱,B账户加钱,数据库记录日志
无论转账操作是否成功,均进行转账操作的日志留痕
二、事务传播行为
事务传播行为:事务协调员对事务管理员所携带事务的处理态度

添加日志是一个新的事务;
事务传播行为:

三、转账日志案例
实现步骤:
第一步、在AccountServiceImpl中调用logService中添加日志的方法, 添加日志是一个新的事务。
            
            
              java
              
              
            
          
          @Service
public class AccountServiceImpl implements AccountService {
    @Autowired
    private AccountDao accountDao;
    @Autowired
    private LogService logService;
    public void transfer(String out,String in ,Double money) {
        try{
            accountDao.outMoney(out,money);
            int i = 1/0;
            accountDao.inMoney(in,money);
        }finally {
            logService.log(out,in,money);
        }
    }
}第二步、在LogService的log()方法上设置事务的传播行为
            
            
              java
              
              
            
          
          public interface LogService {
    //propagation设置事务属性:传播行为设置为当前操作需要新事务
    @Transactional(propagation = Propagation.REQUIRES_NEW)
    void log(String out, String in, Double money);
}第三步、运行测试类,查看结果
            
            
              java
              
              
            
          
          @RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = SpringConfig.class)
public class AccountServiceTest {
    @Autowired
    private AccountService accountService;
    @Test
    public void testTransfer() throws IOException {
        accountService.transfer("Tom","Jerry",50D);
    }
}实现成功。