Spring数据库事务管理

1. Spring数据库事务管理器的设计

在Spring中数据库事务是通过PlatformTransactionManager进行管理的。TransactionTemplate源码:
在这里插入图片描述
在这里插入图片描述
事务的创建、提交和回滚都是通过PlatformTransactionManager接口来完成,当事务产生异常时会回滚事务。在默认的实现中所有的异常都会回滚,我们可以通过配置去修改在某些异常发生时回滚或者不回滚事务。当无异常时会提交事务。
PlatformTransactionManager接口的源码:
在这里插入图片描述
1.配置事务管理器
在这里插入图片描述
在这里插入图片描述这里先引入了 XML 的命名空间,然后定义了数据库连接池,于是使用了
DataSourceTransactionManager去定义数据库事务管理器,并且注入了数据库连接池。这样,Spring就知道已经将数据库事务委托给事务管理器transactionManger管理。
在Spring中可以使用声明式事务或编程式事务,如今编程式事务几乎不用,因为其会产生冗余,代码可读性差。声明式事务分为xml配置和注解事务,但是xml方法也已经不常用了,目前主流的方法是注解@Transaction。
2.用java配置方法实现Spring数据库事务
用java配置的方式实现Spring数据库事务,需要在配置类中实现接口TransactionManagementConfigurer的annotationDrivenTransactionManager方法。Spring将annotationDrivenTransactionManager方法返回的事务管理器作为程序中的事务管理器。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
加粗的代码实现了TransactionManagermentConfigurer接口所定义的方法annotationDrivenTransactionManager,并且我们使用DataSourceTransactionManager去定义数据库事务管理器的实例,再将数据源设置给它。使用注解@EnableTransactionManagement后,在Spring上下文中使用事务注解@Transaction,Spring会知道使用该数据库事务管理器管理事务了。

2. 编程式事务

编程式事务以代码的方式管理事务,事务由开发者通过自己的代码实现,这里需要使用一个事务定义类接口TransactionDefinition。编程式事务的代码如下:
在这里插入图片描述
注意加粗的代码,可以看到所有的事务都是由开发者自己进行控制的,由于事务已经交由事务管理器管理,所以jdbcTemplate本身的数据库资源已经由事务管理器管理,因此当执行完insert语句时不会自动提交事务,这时需要使用事务管理器的commit方法,回滚事务需要使用rollback方法。

3.声明式事务

编程式事务是一种约定型事务,大部分情况下,当使用数据库事务时,大部分场景在代码中发生了异常时,需要回滚事务,而不发生异常时则提交事务,从而保证数据库数据的一致性。
从这点出发,Spring给了一个约定,如果使用的是声明式事务&#

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值