`
uule
  • 浏览: 6308405 次
  • 性别: Icon_minigender_1
  • 来自: 一片神奇的土地
社区版块
存档分类
最新评论

声明式事务

 
阅读更多

跟开涛学Spring

 

数据库事务

      本地事务

      分布式事务

 

Java事务

      JDBC事务

             - 即数据库事务中的本地事务

      JTA事务

             - 只提供了事务管理API接口,由应用服务器提供实现

  

声明式事务

         -- 注解或XML配置文件

编程式事务

         -- 编写代码实现

 

 

Advisor

        指导、教授

        spring里的通知advice 

 

        MethodBeforeAdvice

        一个Advisor是一个切入点和一个通知的组成

         所以可以定义一个事务通知,然后通过advisor实现声明式事务

 

 

声明式事务:

<tx:advice id="txAdvice" transaction-manager="txManager">  
	<tx:attributes>  
		<tx:method name="save*" propagation="REQUIRED" isolation="READ_COMMITTED"/>  
		<tx:method name="*" propagation="REQUIRED" isolation="READ_COMMITTED" read-only="true"/>  
	</tx:attributes>  
</tx:advice>  
<aop:config>  
	<aop:pointcut id="serviceMethod" expression="execution(* cn..chapter9.service..*.*(..))"/>  
	<aop:advisor pointcut-ref="serviceMethod" advice-ref="txAdvice"/>  
</aop:config> 

 

<tx:method  name="save*">:

         表示将拦截以save开头的方法,被拦截的方法将应用配置的事务属性:propagation="REQUIRED"表示传播行为是Required,isolation="READ_COMMITTED"表示隔离级别是提交读;

 

 

多事务语义配置及最佳实践

什么是多事务语义?说白了就是为不同的Bean配置不同的事务属性,因为我们项目中不可能就几个Bean,而可能很多,这可能需要为Bean分组,为不同组的Bean配置不同的事务语义。在Spring中,可以通过配置多切入点和多事务通知并通过不同方式组合使用即可。

 

       1、首先看下声明式事务配置的最佳实践吧:

 

<tx:advice id="txAdvice" transaction-manager="txManager">  
		<tx:attributes>  
		   <tx:method name="save*" propagation="REQUIRED" />  
		   <tx:method name="add*" propagation="REQUIRED" />  
		   <tx:method name="create*" propagation="REQUIRED" />  
		   <tx:method name="insert*" propagation="REQUIRED" />  
		   <tx:method name="update*" propagation="REQUIRED" />  
		   <tx:method name="merge*" propagation="REQUIRED" />  
		   <tx:method name="del*" propagation="REQUIRED" />  
		   <tx:method name="remove*" propagation="REQUIRED" />  
		   <tx:method name="put*" propagation="REQUIRED" />  
		   <tx:method name="get*" propagation="SUPPORTS" read-only="true" />  
		   <tx:method name="count*" propagation="SUPPORTS" read-only="true" />  
		  <tx:method name="find*" propagation="SUPPORTS" read-only="true" />  
		  <tx:method name="list*" propagation="SUPPORTS" read-only="true" />  
		  <tx:method name="*" propagation="SUPPORTS" read-only="true" />  
	   </tx:attributes>  
	</tx:advice>  
	<aop:config>  
		<aop:pointcut id="txPointcut" expression="execution(* cn.javass..service.*.*(..))" />  
		<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut" />  
	</aop:config>  

 

该声明式事务配置可以应付常见的CRUD接口定义,并实现事务管理,我们只需修改切入点表达式来拦截我们的业务实现从而对其应用事务属性就可以了,如果还有更复杂的事务属性直接添加即可,即

如果我们有一个batchSaveOrUpdate方法需要“REQUIRES_NEW”事务传播行为,则直接添加如下配置即可:

<tx:method name="batchSaveOrUpdate" propagation="REQUIRES_NEW" />  

 

2、接下来看一下多事务语义配置吧,声明式事务最佳实践中已经配置了通用事务属性,因此可以针对需要其他事务属性的业务方法进行特例化配置:

<tx:advice id="noTxAdvice" transaction-manager="txManager">  
    <tx:attributes>  
           <tx:method name="*" propagation="NEVER" />  
    </tx:attributes>  
</tx:advice>  
<aop:config>  
       <aop:pointcut id="noTxPointcut" expression="execution(* cn.javass..util.*.*())" />  
       <aop:advisor advice-ref="noTxAdvice" pointcut-ref="noTxPointcut" />  
</aop:config>  

 

       该声明将对切入点匹配的方法所在事务应用“Never”传播行为。

 

       多事务语义配置时,切入点一定不要叠加,否则将应用两次事务属性,造成不必要的错误及麻烦

 

 

@Transactional实现事务管理

       对声明式事务管理,Spring提供基于@Transactional注解方式来实现,但需要Java 5+

 

Spring使用@Transaction来指定事务属性,可以在接口、类或方法上指定,如果类和方法上都指定了@Transaction,则方法上的事务属性被优先使用

 

使用:

1、定义业务逻辑实现

@Transactional(propagation=Propagation.REQUIRED, isolation=Isolation.READ_COMMITTED)  
    @Override  
    public void save(final UserModel user) {  
       ...
    }  

 

2、定义配置文件

 

2.1 命名空间中,定义用于事务支持的tx命名空间和AOP支持的aop命名空间

2.2 业务Bean配置(Service、DAO..)

2.3 事务配置

<tx:annotation-driven/>

 

Spring提供的<tx:annotation-driven/>用于开启对注解事务管理的支持,从而能识别Bean类上的@Transactional注解元数据,其具有以下属性:

transaction-manager:指定事务管理器名字,默认为transactionManager,当使用其他名字时需要明确指定;

proxy-target-class:表示将使用的代码机制,默认false表示使用JDK代理,如果为true将使用CGLIB代理

 

order:定义事务通知顺序,默认Ordered.LOWEST_PRECEDENCE,表示将顺序决定权交给AOP来处理。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics