Spring的事务隔离级别是指在并发环境下,事务之间相互隔离的程度。Spring框架支持多种事务隔离级别,可以根据具体的业务需求来选择合适的隔离级别。以下是常见的事务隔离级别:
1.DEFAULT(默认):使用数据库默认的事务隔离级别。通常为数据库的默认隔离级别,如Oracle为READ COMMITTED,MySQL为REPEATABLE READ。
2.READ_UNCOMMITTED:最低的隔离级别,允许读取未提交的隔离级别。事务可以读取其他事务未提交的数据,可能会导致脏读、不可重复度和幻读的情况。
3.READ_COMMITTED:保证一个事务只能读取到已提交的数据。事务读取的数据是其他事务已经提交的数据,避免的脏读的问题,但可能出现不可重复读和幻读的问题。
4.REPEATABLE-READ:保证一个事务在同一查询中多次读取的数据是一致的。事务期间,其他事务对数据的修改不可见,避免的脏读和不可重复读问题。
5.SERIALIZABLE:最高的隔离级别,保证事务串行执行,避免了脏读、幻读和不可重复读。但是会降低并发性能,因为事务需要串行执行。
在spring中通过@Transactional注解的isolation属性来指定隔离级别
@Transactional(isolation = Isolation READ_COMMITED)
public void method1(){
.......
}
@Transactional(isolation = Isolation REPEATABLE_READ)
public void method2(){
.......
}