spring事物管理之传播行为和隔离级别

你们在使用spring的注解式事务管理时,对事务的传播行为和隔离级别可能有点不知所措,下边就详细的介绍下以备方便查阅。spring

事物注解方式: @Transactionalthis

当标于类前时, 表示类中全部方法都进行事物处理spa

例子:事务

@Transactional
public class TestServiceBean implements TestService {}
get

当类中某些方法不须要事物时:io

@Transactional
public class TestServiceBean implements TestService {
    
    private TestDao dao;
    
    public void setDao(TestDao dao) {
        this.dao = dao;
    }
    
    @Transactional(propagation = Propagation.NOT_SUPPORTED)
    public List<Object> getAll() {
        return null;
    }
    
}
class

事物传播行为介绍: spring事务的传播行为说的是当一个方法调用另外一个方法时,事务该如何操做。容器


@Transactional(propagation=Propagation.REQUIRED) 
若是有事务, 那么加入事务, 没有的话新建一个(默认状况下)
@Transactional(propagation=Propagation.NOT_SUPPORTED) 
容器不为这个方法开启事务
@Transactional(propagation=Propagation.REQUIRES_NEW) 
无论是否存在事务,都建立一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务
@Transactional(propagation=Propagation.MANDATORY) 
必须在一个已有的事务中执行,不然抛出异常
@Transactional(propagation=Propagation.NEVER) 
必须在一个没有的事务中执行,不然抛出异常(与Propagation.MANDATORY相反)
@Transactional(propagation=Propagation.SUPPORTS) 
若是其余bean调用这个方法,在其余bean中声明事务,那就用事务.若是其余bean没有声明事务,那就不用事务.
List

PROPAGATION_NESTED:
若是当前存在一个事务,则该方法运行在一个嵌套的事务中。被嵌套的事务能够从当前事务中单独的提交和回滚。若是当前不存在事务,则开始一个新的事务。各厂商对这种传播行为的支持良莠不齐,使用时需注意。方法

事物超时设置:
@Transactional(timeout=30) //默认是30秒

事务隔离级别:
@Transactional(isolation = Isolation.READ_UNCOMMITTED)
读取未提交数据(会出现脏读, 不可重复读) 基本不使用
@Transactional(isolation = Isolation.READ_COMMITTED)
读取已提交数据(会出现不可重复读和幻读)
@Transactional(isolation = Isolation.REPEATABLE_READ)
可重复读(会出现幻读)
@Transactional(isolation = Isolation.SERIALIZABLE)
串行化

MYSQL: 默认为REPEATABLE_READ级别
SQLSERVER: 默认为READ_COMMITTED

脏读 : 一个事务读取到另外一事务未提交的更新数据
不可重复读 : 在同一事务中, 屡次读取同一数据返回的结果有所不一样, 换句话说, 
后续读取能够读到另外一事务已提交的更新数据. 相反, "可重复读"在同一事务中屡次
读取数据时, 可以保证所读数据同样, 也就是后续读取不能读到另外一事务已提交的更新数据
幻读 : 一个事务读到另外一个事务已提交的insert数据

相关文章
相关标签/搜索