Spring aop事务管理
事务管理
我们在实际业务场景中,经常会遇到数据频繁修改读取的问题。在同一时刻,不同的业务逻辑对同一个表数据进行修改,这种冲突很可能造成数据不可挽回的错乱,所以我们需要用事务来对数据进行管理。事务必须服从ACID原则。ACID指的是原子性(atomicity)、一致性(consistency)、隔离性(isolation)和持久性(durability)。
通俗理解,事务其实就是一系列指令的集合。
编程式事务:所谓编程式事务指的是通过编码方式实现事务,即类似于JDBC编程实现事务管理。管理使用TransactionTemplate或者直接使用底层的PlatformTransactionManager。对于编程式事务管理,spring推荐使用TransactionTemplate。
声明式事务:管理建立在AOP之上的。其本质是对方法前后进行拦截,然后在目标方法开始之前创建或者加入一个事务,在执行完目标方法之后根据执行情况提交或者回滚事务。声明式事务最大的优点就是不需要通过编程的方式管理事务,这样就不需要在业务逻辑代码中掺杂事务管理的代码,只需在配置文件中做相关的事务规则声明(或通过基于@Transactional注解的方式),便可以将事务规则应用到业务逻辑中。
以下用SSM框架示例:
一、搭建好SSM框架
二、在spring-mybatis.xml中配置spring的事务管理器:
<!--事务管理-->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
1、注解式(@Transactional)
在spring-mybatis.xml加入
<!--、开启事务控制的注解支持,配置 Annotation 驱动,扫描@Transactional注解的类定义事务 --><!-- 注解式 -->
<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>
在需要事务回滚的实现方法中加入@Transactional,例如我在TestServiceImpl的Test方法加入@Transactional
@Transactional
public void Test(Test test) throws Exception{
dao.updateByPrimaryKeySelective(test);
int i = 3/0; //主动设置异常
dao.deleteByPrimaryKey(test.getId());
}
需要注意使用@Transactional,需要抛出异常。
2、不使用@Transactional
在spring-mybatis.xml加入
<!--事务管理-->
<!--声明式的 XML配置aop事务 -->
<!-- 配置事务通知 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 以方法为单位,指定方法应用什么事务属性 isolation:隔离级别 propagation:传播行为 read-only:是否只读 -->
<tx:method name="update*" propagation="REQUIRED" />
<tx:method name="delete*" propagation="REQUIRED" />
<tx:method name="get*" propagation="REQUIRED"/>
<tx:method name="find*" propagation="REQUIRED" />
</tx:attributes>
</tx:advice>
<!-- 配置织入 -->
<aop:config>
<!-- 配置切点表达式 -->
<aop:pointcut expression="execution(* cn.com.vtech.service.*ServiceImpl.*(..))" id="txPc" />
<!-- 配置切面 : 通知+切点 advice-ref:通知的名称 pointcut-ref:切点的名称 -->
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPc" />
</aop:config>
(笔记)