声明式事务
1.回顾事务
把一组业务当成一个业务来做;要么都成功要么都失败
2.事务在项目开发中,十分的重要,涉及到数据的一致性问题,不能马虎
3.确保完整性和一致性
事务ACID原则:
1.原子性
2.一致性
3.隔离性
多个业务可能操作同一个资源,防止数据损坏
4.持久性
事务一旦提交,无论系统发生什么问题,结果都不会再被影响,被持久化的写到存储器中
2.spring中的事务管理
声明式事务:AOP
编程式事务:需要在代码中进行事务的管理
要开启 Spring 的事务处理功能,在 Spring 的配置文件中创建一个 DataSourceTransactionManager 对象:
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<constructor-arg ref="dataSource" />
</bean>
结合Aop实现事务的织入
<!-- 结合Aop实现事务的织入 -->
<!-- 配置事务通知-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<!-- 给哪些方法配置事务-->
<!-- 配置事务的传播特性:new propogation -->
<tx:attributes>
<tx:method name="add" propagation="REQUIRED"/>
<tx:method name="delete" propagation="REQUIRED"/>
<tx:method name="update" propagation="REQUIRED"/>
<tx:method name="query" read-only="true"/>
<tx:method name="*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
事务种类 | 描述 |
---|---|
REQUIRED | 如果当前没有事务,就创建一个新事务,如果当前存在事务,就加入该事务,该设置是最常用的设置 |
SUPPORTS | 支持当前事务,如果当前存在事务,就加入该事务,如果当前不存在事务,就以非事务执行 |
MANDATORY | 支持当前事务,如果当前存在事务,就加入该事务,如果当前不存在事务,就抛出异常 |
REQUIRES_NEW | 创建新事务,无论当前存不存在事务,都创建新事务 |
NOT_SUPPORTED | 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起 |
NEVER | 以非事务方式执行,如果当前存在事务,则抛出异常 |
NESTED | 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类似的操作 |
配置事务切入
<!-- 配置事务切入-->
<aop:config>
<aop:pointcut id="txPointCut" expression="execution(* com.annan.mapper.*(..))"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointCut"/>
</aop:config>
直接测试,可以看到事务要么都成功要么都失败
思考:为什么需要事务?
1.如果不配置事务,可能存在数据提交不一致的情况,如取出了钱但账户余额没减少
2.如果我们不在Spring中去配置声明式事务,我们就需要在代码中手动配置事务
3.事务在项目的开发中十分重要,设计到数据的一致性和完整性,不容马虎