Spring在TransactionDefinition接口中规定了7种类型的事务传播行为。事务传播行为是Spring框架独有的事务增强特性,他不属于的事务实际提供方数据库行为。默认的传播行为是:PROPAGATION_REQUIRED
事务传播行为类型 | 说明 |
---|---|
PROPAGATION_REQUIRED | 如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。这是最常见的选择。 |
PROPAGATION_SUPPORTS | 支持当前事务,如果当前没有事务,就以非事务方式执行。 |
PROPAGATION_MANDATORY | 使用当前的事务,如果当前没有事务,就抛出异常。 |
PROPAGATION_REQUIRES_NEW | 新建事务,如果当前存在事务,把当前事务挂起。 |
PROPAGATION_NOT_SUPPORTED | 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。 |
PROPAGATION_NEVER | 以非事务方式执行,如果当前存在事务,则抛出异常。 |
PROPAGATION_NESTED | 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作。 |
在使用PROPAGATION_REQUIRES_NEW 注意点:
使用PROPAGATION_REQUIRES_NEW 会把当前事务挂起,创建新的子事务,也会重新获取新的连接,那么一个请求消耗的数据库连接会增加,如果并发高,请求量大的接口,此用法会增加系统的RT。当然这也能解决某些场景问题。比如一些主流程需要记录日志,不管主流程是否成功,日志都需要记录下来,那么我们可以在LogService的saveLog()方法的事务传播行为定义为PROPAGATION_REQUIRES_NEW 。此处也需要注意,如果saveLog发生异常,那么整个事务也会回滚。
网友评论