多数据源下, 加了@Transactional(rollbackFor = Exception.class)后发现,数据源切换不了.

不加事务注解,即只有@DataSourceChange时的流程是,程序执行到fetchRawDataForCriterias()方法时,会先去执行 doAround()方法,设置当前线程的数据源.

然后执行 determinCurrentLookupKey()方法,得到当前线程的数据源.

加了@Transactiona后,发现程序会第一时间执行determineCurrentLookupKey(), 后面又执行doAround()方法.但是再后面就不执行determinCurrentLookupKey()了.这就导致,数据源没有实现切换.
解决方法:调整两个annotation执行的先后顺序,先执行@DataSourceChange(hopper = true),于是修改下面代码,加一个Order注解

如果觉得本篇文章有所帮助,请帮忙微信扫描下本人写的一个实用小程序 “安全期随时看”,让你随时掌握爱爱时间,多谢帮助!
---------------------------
-------------------------
-------------------------------------------安全期随时看---------------------------------------------
spring多数据源下 事务不生效
最新推荐文章于 2025-02-25 23:16:00 发布
本文探讨了在使用多数据源的情况下,加入@Transactional注解后导致的数据源切换失败问题。通过调整@DataSourceChange和@Transactional的执行顺序解决了该问题。
1万+

被折叠的 条评论
为什么被折叠?



