spring事务自动管理机制有很多方式,不过这里讨论的是采用AOP的Tx处理机制
如果你的spring配置是分开来配置,那么这里以applicationContext-service.xml配置如下,在ibatis里面不用再多加配置
<!-- 声明一个数据源事务管理 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<!-- AOP的pointcut切面编程 ,声明spring处理逻辑层做事务自动回滚,DAO层不做-->
<aop:config>
<!--aop:advisor id="userManagerTx" advice-ref="userManagerTxAdvice"
pointcut="execution(* *..service.UserManager.*(..))" order="0" /-->
<aop:advisor id="managerTx" advice-ref="txAdvice"
pointcut="execution(* *..service.*Manager.*(..))" order="0" />
</aop:config>
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="get*" read-only="true" />
<tx:method name="update*" rollback-for="Exception" />
<tx:method name="remove*" rollback-for="Exception" />
<tx:method name="insert*" rollback-for="Exception" />
<tx:method name="save*" rollback-for="Exception" />
<tx:method name="*" />
</tx:attributes>
</tx:advice>
配置完上面后,下面就做一个用例测试一下,简单写一个manager类
public class CrossTestuserDaoiBatis
extends BaseDaoiBATIS
implements CrossTestuserDao {
public int removeCrossTester(int uuid){
Integer result = (Integer)getSqlMapClientTemplate().delete("delcrossuser",uuid);
int i = 1/0;
return result.intValue();
}
}
注意:上面是一段关于删除数据的代码,删除提交事务后,假设一个不能整除0的函数,在这里抛出异常,测试的结果是,刚才已经删除的数据自动被自动回滚事务捕捉到,结果把刚才那笔数据回滚,这样就达到只需简单设定配置,不需要写代码就能轻松管理spring的AOP提供的强大事务管理机制