上一篇博客讲解了Spring配置xml事务,使用的是Spring框架提供的事务管理器。

在本篇博文当中,来讲解一下使用自定义的事务管理方式。

把上一篇博文当中的这个配置

<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

<property name="dataSource" ref="dataSource"/>

</bean>

修改为如下的配置:

<bean id="transactionManager" class="com.cat.aop.TransactionAdvice">

<property name="ds" ref="dataSource"/>

</bean>

这部分代码注销:

<tx:advice id="txAdvice" transaction-manager="transactionManager">

<!-- 事务属性 -->

<tx:attributes>

<tx:method name="*"/>

<tx:method name="get*" read-only="true"/>

<tx:method name="find*" read-only="true"/>

<tx:method name="list*" read-only="true"/>

<!--增删改 -->

<tx:method name="insert*" timeout="5000" rollback-for="java.lang.Exception"/>

<tx:method name="add*" timeout="5000"/>

<tx:method name="update*" timeout="5000"/>

<tx:method name="delete*" timeout="5000"/>

</tx:attributes>

</tx:advice>

因为使用aop进行拦截,就不在需要上面的代码。

aop:config的配置修改为:

<aop:config>

<!-- 正确配置方式 -->

<aop:pointcut id="pt" expression="execution(* com.cat.service.impl.CatServiceImpl.*(..))"/>

<aop:aspect ref="transactionManager">

<aop:around method="tranAround" pointcut-ref="pt"/>

</aop:aspect>

</aop:config>

添加一个自定义事务管理TransactionAdvice类的代码如下

public class TransactionAdvice {

private DataSource ds;

public void setDs(DataSource ds) {

this.ds = ds;

}

public TransactionAdvice() {

}

public TransactionAdvice(DataSource ds) {

this.ds = ds;

}

public Object tranAround(ProceedingJoinPoint pj) throws Throwable {

//开启事务 (

//事务管理器

DataSourceTransactionManager ptm = new DataSourceTransactionManager();

//事务管理器中,需要注入 dataSource

ptm.setDataSource(ds);

//声明事务

TransactionDefinition td = new DefaultTransactionDefinition();

//事务状态

TransactionStatus ts =ptm.getTransaction(td);

Object obj=pj.proceed();

ptm.commit(ts);

return obj;

}

}

注意这个类中ds需要和

<bean id="transactionManager" class="com.cat.aop.TransactionAdvice">

<property name="ds" ref="dataSource"/>

</bean>

这个位置的一致。

执行前的数据为:

运行后的结果为

再次查看数据库,刷新后的结果如下

事务正确回滚,达到目的。

如果把10 / 0去掉,再次执行。

查看结果,执行成功,第一条数据名称修改成功,第二条数据物理删除成功!

至此自定义事务管理的整个流程全部打通。

真实的开发中,还是建议配置为Spring自带的事务管理器,一般很少出现自己去添加

自定义事务管理器的情况。各位小伙伴有其他更好建议的,欢迎留言。

Spring配置xml自定义事务管理器的更多相关文章

  1. spring配置多个事务管理器

    <tx:annotation-driven/> <bean id="transactionManager1" class="org.springfram ...

  2. Spring3.0配置多个事务管理器(即操作多个数据源)的方法

    大多数项目只需要一个事务管理器.然而,有些项目为了提高效率.或者有多个完全不同又不相干的数据源,最好用多个事务管理器.机智的Spring的Transactional管理已经考虑到了这一点,首先分别定义 ...

  3. spring 配置事务管理器

    在Spring中数据库事务是通过PlatformTransactionManager进行管理的,jdbcTemplate是不能支持事务的,而能够支持事务的是org.springframework.tr ...

  4. spring的annotation-driven配置事务管理器详解

    http://blog.sina.com.cn/s/blog_8f61307b0100ynfb.html ——————————————————————————————————————————————— ...

  5. Spring事务管理器的应对

    Spring抽象的DAO体系兼容多种数据访问技术,它们各有特色,各有千秋.像Hibernate是非常优秀的ORM实现方案,但对底层SQL的控制不太方便:而iBatis则通过模板化技术让你方便地控制SQ ...

  6. 跟我学Spring3(9.2):Spring的事务之事务管理器

    原文出处: 张开涛9.2.1 概述 Spring框架支持事务管理的核心是事务管理器抽象,对于不同的数据访问框架(如Hibernate)通过实现策略接口PlatformTransactionManage ...

  7. Spring jdbctemplate和事务管理器 全注解配置 不使用xml

    /** * spring的配置类,相当于bean.xml */@Configuration//@Configuration标注在类上,相当于把该类作为spring的xml配置文件中的<beans ...

  8. 解决在Spring整合Hibernate配置tx事务管理器出现错误的问题

    问题描述: Error occured processing XML 'org/aopalliance/intercept/MethodInterceptor'. See Error Log for ...

  9. spring事务管理器的源码和理解

    原文出处: xieyu_zy 以前说了大多的原理,今天来说下spring的事务管理器的实现过程,顺带源码干货带上. 其实这个文章唯一的就是带着看看代码,但是前提你要懂得动态代理以及字节码增强方面的知识 ...

  10. Spring事务管理器

    1.创建实体和接口 public class Bank { private Integer id; private String name; private String manay; public ...

随机推荐

  1. 物色到的 c# 模拟 http post get 请求 做下笔记

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.N ...

  2. git操作 手写稿

  3. 执行orachk检查数据库环境

    Exadata环境巡检需要执行专有的exachk,而普通Oracle环境可以通过执行orachk来检查集群和数据库相关健康状况. 1.使用orachk检查健康状态 使用root用户执行,期间可能需要多 ...

  4. ASP.NET Core分布式项目实战(业务介绍,架构设计,oAuth2,IdentityServer4)--学习笔记

    任务4:第一章计划与目录 敏捷产品开发流程 原型预览与业务介绍 整体架构设计 API 接口设计 / swagger Identity Server 4 搭建登录 账号 API 实现 配置中心 任务5: ...

  5. Kafka-常用命令行命令(Kafak3.4.0最新命令)

    第一章 Kafka常用命令 1. Topic(主题) 1.1. 创建Topic bin/kafka-topics.sh --create --bootstrap-server hadoop01:909 ...

  6. Flink-SQL数据去重

    Flink去重语句 您可以通过多种方式实现去重需求,例如FIRST_VALUE.LAST_VALUE和DISTINCT等.本文为您介绍如何使用TopN方法实现去重,以及使用过程中的注意事项. 去重的方 ...

  7. [刺客伍六七&黑客] 魔刀千刃evilblade的使用手册与开源

    0x00 前言 2023.8.15 夜里 非常欢迎使用我的魔刀千刃,并且欢迎各位师傅对我的开源代码进行指导! -–Offense without defense, unparalleled in th ...

  8. JS leetcode 删除排序数组中的重复项 题解分析

    壹 ❀ 引 一日一题,今天的题目来自于leetcode26. 删除排序数组中的重复项,其实在之前我们已经做了一道类似的题目,可参考JS leetcode 移除元素 题解分析,关于本题描述如下: 给定一 ...

  9. NC51178 没有上司的舞会

    题目链接 题目 题目描述 Ural大学有N名职员,编号为1~N. 他们的关系就像一棵以校长为根的树,父节点就是子节点的直接上司. 每个职员有一个快乐指数,用整数 \(Hi\) 给出,其中 \(1\le ...

  10. Spring Boot整合Postgres实现轻量级全文搜索

    有这样一个带有搜索功能的用户界面需求: 搜索流程如下所示: 这个需求涉及两个实体: "评分(Rating).用户名(Username)"数据与User实体相关 "创建日期 ...