前一段时间项目中用到了Spring的事物管理(Spring注解事物),学习了一下也没有搞太明白。
但是个人觉得spring 事物管理至少要搞懂三个东西(1.事物回滚问题. 2.事物的传播行为. 3.事物的隔离级别)
1.事物回滚问题:声明式事物默认支持unCheckException回滚,checkException不回滚,但是有时候我们需要改变这种默认回滚方式。
2.事物的传播行为:主要是处理比方某个方法不需要支持事物(查询),或者事物方法发生互相调用的时候来统一事物管理。
3.事物的隔离级别:主要处理数据库表记录发生不同步时的问题(什么脏读,什么幻读)
呵呵,小弟倒现在对这三个东东还是模糊,个人是这样认为的(望高手指点啊)
下面是网上摘的(Spring注解事物与传播行为),帖下面充当学习

Spring使用声明式事务处理,默认情况下,如果被注解的数据库操作方法中发生了unchecked异常,所有的数据库操作将rollback;如果发生的异常是checked异常,默认情况下数据库操作还是会提交的。

这种默认的行为是可以改变的。使用@Transactional注解的noRollbackForrollbackFor属性,如:@Transactional(rollbackFor=Exception.class)可以使checked异常发生时,数据库操作也rollback@Transactional(noRollbackFor=RuntimeException.class)可以使unchecked异常发生时也提交数据库操作。也可以使用noRollbackForClassNamerollbackForClassName属性来指定一个异常类名的String数组来改变默认的行为。

 

读取数据库中的数据时是不需要事务管理的,这种情况下可以使用事务的传播行为来告诉Spring不需要开启事务,如:@Transactional(propagation = Propagation.NOT_SUPPORTED)

事务的传播行为有:

1.           REQUIRED:表示业务方法需要在一个事务中处理,如果业务方法执行时已经在一个事务中,则加入该事务,否则重新开启一个事务。这也是默认的事务传播行为;

2.           NOT_SUPPORTED:声明业务方法不需要事务,如果业务方法执行时已经在一个事务中,则事务被挂起,等方法执行完毕后,事务恢复进行;

3.           REQUIRES_NEW:表明业务方法需要在一个单独的事务中进行,如果业务方法进行时已经在一个事务中,则这个事务被挂起,并重新开启一个事务来执行这个业务方法,业务方法执行完毕后,原来的事务恢复进行;

4.           MANDATORY:该属性指定业务方法只能在一个已经存在的事务中进行,业务方法不能发起自己的事务;如果业务方法没有在一个既有的事务中进行,容器将抛出异常;

5.           SUPPORTS:该属性指定,如果业务方法在一个既有的事务中进行,则加入该事务;否则,业务方法将在一个没有事务的环境下进行;

6.           NEVER:指定业务方法不可以在事务中进行,如果业务方法执行时已经在一个事务中,容器将抛出异常;

7.           NESTED:该属性指定,如果业务方法在一个既有的事务中执行,则该业务方法将在一个嵌套的事务中进行;否则,按照REQUEIRED来对待。它使用一个单独的事务,这个事务可以有多个rollback点,内部事务的rollback对外部事务没有影响,但外部事务的rollback会导致内部事务的rollback。这个行为只对DataSourceTransactionManager有效。

 

事务的隔离级别

  使用@TransactionalIsolation属性可以指定事务的隔离级别。但事务的隔离级别是由底层的数据库实现的,并不是由Spring来实现。

1.       READ_UNCOMMITTED:会出现脏读、不可重复读和幻读问题

2.       READ_COMMITTED:会出现不可重复读和幻读问题;

3.       REPEATABLE_READ:会出现幻读问题;

4.       SERIALIZABLE:串行化,不会出现上面的问题。

  一般的数据库默认提供的是READ_COMMITTED隔离级别,如sqlserver2000Mysql默认提供的是REPEATABLE_READ

补充 : 基于元数据的 Spring 声明性事务 :

Isolation 属性一共支持五种事务设置,具体介绍如下:

l DEFAULT 使用数据库设置的隔离级别 ( 默认 ) ,由 DBA 默认的设置来决定隔离级别 .

l READ_UNCOMMITTED 会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 )

l READ_COMMITTED 会出现不可重复读、幻读问题(锁定正在读取的行)

l REPEATABLE_READ 会出幻读(锁定所读取的所有行)

l SERIALIZABLE 保证所有的情况不会发生(锁表)

不可重复读的重点是修改 :
同样的条件 ,   你读取过的数据 ,   再次读取出来发现值不一样了
幻读的重点在于新增或者删除
同样的条件 ,   第 1 次和第 2 次读出来的记录数不一样

脏读  不可重复读   幻读  
Serializable  不会  不会         不会  
REPEATABLE READ  不会  不会         会    
READ COMMITTED   不会  会           会    
Read Uncommitted 会    会           会