场景一 test1 方法没有事务 test2 方法有事务,包括2个insert方法, test1 调用test2 ,结果,test1 和test2 都没有事务了,
public void test1() {
test2();
}
@Transactional(propagation = Propagation.REQUIRED)
public void test2() {
Team team = new Team();
team.setPath("t1111");
BigInteger quota = new BigInteger("0");
team.setQuota(quota);
commonDao.save(team);
Team team2 = new Team();
team.setPath("t222");
team2.setQuota(quota);
commonDao.save(team2);
}
上面的情况是在a方法 b方法都在同一个service中时
场景二
如果a,b 方法 在不同的service时 a 有事务 b 没事务会回滚 a 没事务 b有事务 b回滚a不回滚
解释: 场景一中test1调用test2,是同一个对象中的方法调用,不会调用spring代理方法,而是直接掉用原始方法。因此test2的事物注解不生效。
最好附上事务用到的注解 spring 事务注解
默认遇到throw new RuntimeException("...");会回滚
需要捕获的throw new Exception("...");不会回滚
// 指定回滚@Transactional(rollbackFor=Exception.class)
public void methodName() {
// 不会回滚
throw new Exception("...");
}
//指定不回滚@Transactional(noRollbackFor=Exception.class)
public ItimDaoImpl getItemDaoImpl() {
// 会回滚
throw new RuntimeException("注释");
}
// 如果有事务,那么加入事务,没有的话新建一个(不写的情况下)
@Transactional(propagation=Propagation.REQUIRED)
// 容器不为这个方法开启事务
@Transactional(propagation=Propagation.NOT_SUPPORTED)
// 不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务
@Transactional(propagation=Propagation.REQUIRES_NEW)
// 必须在一个已有的事务中执行,否则抛出异常
@Transactional(propagation=Propagation.MANDATORY)
// 必须在一个没有的事务中执行,否则抛出异常(与Propagation.MANDATORY相反)
@Transactional(propagation=Propagation.NEVER)
// 如果其他bean调用这个方法,在其他bean中声明事务,那就用事务.如果其他bean没有声明事务,那就不用事务.
@Transactional(propagation=Propagation.SUPPORTS)
/*
public void methodName(){
// 本类的修改方法 1
update();
// 调用其他类的修改方法
otherBean.update();
// 本类的修改方法 2
update();
}
other失败了不会影响 本类的修改提交成功
本类update的失败,other也失败
*/@Transactional(propagation=Propagation.NESTED)
// readOnly=true只读,能插入,但不能更新,删除 @Transactional (propagation = Propagation.REQUIRED,readOnly=true)
// 设置超时时间@Transactional (propagation = Propagation.REQUIRED,timeout=30)
// 设置数据库隔离级别@Transactional (propagation = Propagation.REQUIRED,isolation=Isolation.DEFAULT)