mybatis-spring 如何整合的spring事物

探讨MyBatis如何在执行SQL时通过Spring的DataSourceTransactionManager获取连接,并整合Spring事务管理,实现自动提交与手动提交的切换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mybatis在执行sql时,首先要去获取连接

具体代码位置,调用BaseExecutor.getConnection()方法去获取连接,进而调用transaction.getConnection()

 

transaction是在使用SqlSessionFactoryBean时注入,具体代码位置

 

 

SpringManagedTransaction.getConnection方法中就整合进了Spring的事物管理,如果配置了spring的事物,则82行代码获取的连接则是DataSourceTransactionManager创建的连接,也就是110行代码获取,如果没有配置则是由如下代码创建在115行,115行获取的连接是自动提交的。此时也没有使用spring的事物管理 

当存在spring事物管理时,mybatis-spring的事物提交就交给spring了,如果不存在则在如下代码位置进行提交,不过这里提交已经没有任何作用了,因为可以从前面看到创建的连接是自动提交的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值