spring编程式事务
Spring (jdbc事务管理)
Spring 实现编程式事务,依赖于2大类,分别是 DataSourceTransactionManager(事务管理器),与 TransactionTemplate(事务模板)。下面详细介绍 Spring是如何通过该类实现事务管理,我这里模拟转账业务
首先给所有准备工作做好,导入所有需要的 jar
1:建立数据库连接资源文件,我这里是 mysql 的
2.引入外部资源文件,建立数据库连接池
我这里使用的是阿里的 DruidData
3.创建 dao 类(接口省略,与平常一样)
注意:这里需要实现 jdbcDaoSupport 接口,在执行操作时使用父类的 getJdbcTemplate()方法进行操作
在 spring.xml 核心配置文件中配置 jdbcTemplate模板
4.在 spring.xml 核心配置文件中配置事务模板
5.在 spring.xml 核心配置文件中配置事务管理器
6.创建 service 类(接口省略)
创建 dao 引用,创建 transactionTemplate 引用,在操作方法中使用 transcationTemplate对象的 execute方法()传入参数,new Tran……接口,以内部类的方式去实现该接口
7.在 spring.xml 核心配置文件中配置 service bean
8.在 spring.xml 核心配置文件中配置 dao bean
test 测试
100用户给102用户转账500
转账前数据
运行结果:
这里报的被除数不能为0是我故意在 service 中制造的异常,这里已经运行了 dao 方法,并且发送了修改语句,在转账途中遇到了错误,这时我们所配置的事务就有效果了
转账后数据:
这里的数据没有变,说明事务回滚了
温馨提示:spring 编程式事务不推荐使用,代码量大,代码耦合严重