天天看点

spring的声明式事务

关于事务配置的详解:spring事务配置的五种方式

<a href="http://www.blogjava.net/robbie/archive/2009/04/05/264003.html" target="_blank">http://www.blogjava.net/robbie/archive/2009/04/05/264003.html</a>

事务的传播特性

在我们用ssh开发项目的时候,我们一般都是将事务设置在service层那么当我们调用service层的一个方法的时候它能够保证我们的这个方法中执行的所有的对数据库的更新操作保持在一个事务中,在事务层里面调用的这些方法要么全部成功,要么全部失败。那么事务的传播特性也是从这里说起的。

如果你在你的service层的这个方法中,除了调用了dao层的方法之外,还调用了本类的其他的service方法,那么在调用其他的service方法的时候,这个事务是怎么规定的呢,我必须保证我在我方法里掉用的这个方法与我本身的方法处在同一个事务中,否则如果保证事物的一致性。事务的传播特性就是解决这个问题的,“事务是会传播的”在spring中有针对传播特性的多种配置我们大多数情况下只用其中的一种:propgation_required:这个配置项的意思是说当我调用service层的方法的时候开启一个事务(具体调用那一层的方法开始创建事务,要看你的aop的配置),那么在调用这个service层里面的其他的方法的时候,如果当前方法产生了事务就用当前方法产生的事务,否则就创建一个新的事务。这个工作使由spring来帮助我们完成的。

以前没有spring帮助我们完成事务的时候我们必须自己手动的控制事务,例如当我们项目中仅仅使用hibernate,而没有集成进spring的时候,我们在一个service层中调用其他的业务逻辑方法,为了保证事物必须也要把当前的hibernate session传递到下一个方法中,或者采用threadlocal的方法,将session传递给下一个方法,其实都是一个目的。现在这个工作由spring来帮助我们完成,就可以让我们更加的专注于我们的业务逻辑。而不用去关心事务的问题。

默认情况下当发生runtimeexception的情况下,事务才会回滚,所以要注意一下如果你在程序发生错误的情况下,有自己的异常处理机制定义自己的exception,必须从runtimeexception类继承这样事务才会回滚

配置@transactional(rollbackfor=exception.class)

即使是抛出的是非运行时异常也会回滚

spring的声明式事务

参考文章:

<a href="http://blog.sina.com.cn/s/blog_6b338038010109tm.html" target="_blank">http://blog.sina.com.cn/s/blog_6b338038010109tm.html</a>

使用spring声明式事务的几个步骤:

       1. applicationcontext.xml中进行配置