1.第一步:配置sessionFactory或者dataSource
- 第二步:定义事务管理器(声明式的事务)
<!-- 第三步:配置事务方法传播特性 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="get*" propagation="REQUIRED" read-only="true" />
<tx:method name="find*" propagation="REQUIRED" read-only="true" />
<tx:method name="query*" propagation="REQUIRED" read-only="true" />
<tx:method name="load*" read-only="true" />
<tx:method name="*Event" read-only="true" />
<tx:method name="*Task" read-only="true" />
<tx:method name="barrier*" isolation="READ_UNCOMMITTED" />
<tx:method name="read*" isolation="READ_UNCOMMITTED" />
<tx:method name="sync*" propagation="NEVER" />
<tx:method name="nver*" propagation="NEVER" />
<tx:method name="supports*" propagation="SUPPORTS" />
<tx:method name="notsupported*" propagation="NOT_SUPPORTED" />
<tx:method name="*" />
</tx:attributes>
</tx:advice>
<!-- 第四步:配置事务aop切面 -->
<aop:config>
<aop:pointcut id="interceptorPointCuts" expression="execution(* com.spring.service.*.*(..))" />
<!-- 管理所有的service -->
<aop:advisor advice-ref="txAdvice" pointcut-ref="interceptorPointCuts" />
<!-- 增强,进行事务控制 Advisor -->
</aop:config>
</bean>
一、Spring的事务四大特性:
1、原子性:强调事务的不可分割.;
2、一致性:事务执行前后数据的完整性保持不变(事务执行前,A和B的总钱数为500,进行转账操作后,A和B的总钱数还应该是500);
3、隔离性:不同事务之间是相互独立的;
4、持久性:事务一旦执行提交操作就会持久化到数据库
二、Spring的事务隔离级别:
有4大隔离级别,分别是:读未提交(read uncommited)、读已提交(read commited)、可重复读(repeatable read)、串行化(serializable),隔离级别一次递增。
注:Mysql默认为可重复读(repeatable read)
oracle默认为读已提交(read commited)
1、读未提交(read uncommited):会出现脏读(脏读:事务A执行了修改还未提交、事务B读取到了这条记录,但事务A又执行了回滚,事务B就出现了脏读);
2、读已提交(read commited):可以防止脏读,但在事务A两次读取的过程中,事务B修改了这条记录并提交,就会早成事务A两次读取的结果不一致的情况,称为不可重复读(两次读取的结果不一样,重复读就可以发现);
3、可重复读(repeatable read):可以防止脏读、不可重复读的问题,但是当事务A第一次读取记录后,事务B 执行修改操作并提交,事务A第二次读取时,会读取到事务B提交的记录,造成事务A两次读到的结果不一致,就会出现幻读的问题;
4、串行化(serializable):事务执行时,会在所有级别上加锁,仿佛事务就是以串行的方式执行的,可以防止脏读、不可重复读、幻读的问题、但是会带来性能的下降。
三、Sprong的传播特性:
1、PROPAGATION_REQUIRED:支持当前事务,若当前存在事务,则支持当前事务,若不存在,则另开启新的事务;
2、PROPAGATION_SUPPORTS:支持当前事务,若当前存在事务,则支持当前事务,若不存在,则以无事务的状态执行;
3、PROPAGATION_MANDATORY:支持当前事务,若当前存在事务,则支持当前事务,若不存在,则抛出异常;
4、PROPAGATION_REQUIRES_NEW:新开事务执行,若当前存在事务,则挂起当前事务;
5:PROPAGATION_NOT_SUPPORTED:以无事务状态执行,若存在事务则挂起;
6:PROPAGATION_NEVER:以非事务状态执行,若存在事务则抛异常;
7、PROPAGATION_NESTED:当前存在事务,则嵌套一个新事务,当前不存在事务,则新开事务