实现spring事务的四种方式

本文通过银行转账案例介绍Spring事务管理的重要性,并详细阐述了四种实现方式:编程式事务管理、基于TransactionProxyFactoryBean的声明式事务、基于AspectJ的XML配置以及基于注解的事务管理。在实际开发中,基于注解的方式因配置简单而常用。
摘要由CSDN通过智能技术生成


用一个银行账号转钱的案例来说明spring事务的实现。

在转钱过程中,一个账号钱增加,另一个减少,那么当有异常产生时,就会出现钱转丢了的现象

一个减少了,而另一个没有增加,这个时候就需要把这两个行为绑定到一起,要么同时发生,要么都不发生

这就用到了事务,事务就是指在逻辑上的一组操作,这组操作要么全部成功,要么全部失败


实现spring事务的四种方式分别为:

(1)编程式事务管理:需要手动编写代码,在实际开发中很少使用

(2)声明式事务管理:

(2.1)基于TransactionProxyFactoryBean的方式,需要为每个进行事务管理的类做相应配置

(2.2)基于AspectJ的XML方式,不需要改动类,在XML文件中配置好即可

(2.3)基于注解的方式,配置简单,需要在业务层类中添加注解


(2.2)和(2.3)在开发中使用比较多,前者配置一目了然,可以在XML文件中得到所有信息,后者配置简单方便


需要做的一些准备工作:


1.在数据库中新建一张account数据表

SQL脚本:

CREATE TABLE `account` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(20) NOT NULL,
  `money` double DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
INSERT INTO `account` VALUES ('1', 'aaa', '1000');
INSERT INTO `account` VALUES ('2', 'bbb', '1000');
INSERT INTO `account` VALUES ('3', 'ccc', '1000');


2.需要引入的Jar包




3.为数据库连接准备的配置文件- jdbc.properties

使用c3p0数据库连接池


jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\://127.0.0.1\:3306/test
jdbc.username=root
jdbc.password=



4.创建两个接口

  • 1
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值