SpringAOP事务配置语法及实现过程详解

时间:2021-05-19

配置事务: 使用的tx前缀的标签, 导入tx的命名空间

配置事务管理器 , 把事务管理器交给Spring管理:

<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <!-- 注入DataSource --> <property name="dataSource" ref="dataSource"/></bean>

事务的策略

transaction-manager: 事务增强基于那个事务管理器, 默认值: transactionManager(bean的id)

如果事务管理器的id为transactionManager, 在tx:advice标签中不需要添加transaction-manager属性

<tx:advice id="txAdvice" transaction-manager="txManager"><!-- 声明事务的规则 : 针对业务层的不同的方法,采用不同的规则--> <tx:attributes>      <tx:method name="find*" read-only="true" propagation="SUPPORTS" /> <tx:method name="query*" read-only="true" propagation="SUPPORTS"/> <tx:method name="get*" read-only="true" propagation="SUPPORTS"/> <tx:method name="add*" propagation="REQUIRED" rollback-for="java.lang.Exception"/> <tx:method name="del*" propagation="REQUIRED" rollback-for="java.lang.Exception" timeout="2"/> <tx:method name="update*" propagation="REQUIRED" rollback-for="java.lang.Exception"/> <tx:method name="*" propagation="REQUIRED"/> </tx:attributes></tx:advice>

事务规则的语法:

name: 表示业务层的方法名

read-only: 只读, true 查询中使用这个属性, 默认值: false

propagation: 事务传播机制:

*** REQUIRED:默认值,表示如果存在一个事务,则支持当前事务,如果当前没有事务,则开启一个新的事务. 增删改
*** SUPPORTS:表示如果存在一个事务,则支持当前事务,如果当前没有事务,则按非事务方式执行, 查询
MANDATORY:表示如果存在一个事务,则支持当前事务,如果当前没有事务,则抛出异常
REQUIRES_NEW:表示总是开启一个新的事务,如果当前有一个事务,则将当前事务挂起,开启新事物执行方法.
NOT_SUPPORTED:表示总是以非事务方式执行.如果一个事务已经存在,则将这个存在的事务挂起,然后执行方法.
NEVER:表示总是以非事务方式执行.如果当前存在一个活动的事务,则抛出异常
NESTED:表示如果当前存在一个活动的事务,则创建一个事务作为当前事务的嵌套事务运行,如果没有当前事务,该取值与REQUIRED相同.

timeout: 超时, -1 永不超时, 默认值, 正整数, 单位秒

rollback-for="异常类型", 针对哪一种异常类型进行回滚, ,默认值:RuntimeException

no-rollback-for="异常类型", 不对哪一种异常类型进行回滚

isolation: 事务隔离级别: 数据库来决定

DEFAULT:默认值,表示使用数据库默认的事务隔离级别
READ_UNCOMMITTED:读未提交, 读取到未提交的数据, 所有的数据库都不采用
READ_COMMITTED:读已提交 oracle
REPEATABLE_READ: 可重复读 mysql
SERIALIZABLE: 串行读 安全性最高, 效率最低

timeout: 从执行业务方法开始,到执行完sql语句之间的时候

事务的织入 (把这个事务的通知对那些类的那些方法进行增强)

<!-- 事务的织入 ,把这个事务的通知对那些类的那些方法进行增强--> <aop:config> <!-- 切入点--> <aop:pointcut expression="execution(* spring07.service..*.*(..))" id="pointcut1"/> <!-- 织入 advice-ref: 通知类的bean pointcut-ref: 切入点 --> <aop:advisor advice-ref="txAdvice" pointcut-ref="pointcut1"/> </aop:config>

脏读 :一个事务读到了另一个事务的未提交的数据

不可重复读 :一个事务读到了另一个事务已经提交的 update 的数据导致多次查询结果不一致

幻读 :一个事务读到了另一个事务已经提交的 insert 的数据导致多次查询结果不一致

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章