@Transaction 注解导致动态切换更改数据库失效

本文探讨了在使用@Transaction注解时动态切换数据源失效的问题。具体表现为,在Controller方法上使用@Transaction后,数据源无法根据HTTP请求头动态切换。解决方法是避免在Controller层级使用事务注解或将业务逻辑放置于Service层。

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

@Transaction 注解导致动态切换更改数据库失效

使用场景

  1. 给所有的Controller方法上加切点
  2. @Before注解的方法里,根据http请求中携带的header,动态切换数据源
  3. 使用mybatis或者jpa执行操作

遇到问题

当给Controller方法加上@Transaction注解后,动态切换数据源就失效了,原因是每次@Before注解的方法运行之前,protected abstract Object determineCurrentLookupKey();就已经运行了,而这个方法是切换数据源的关键。

解决

其实也算不上解决,就是不要在Controller方法上加事务注解,非要加事务,中间的Service层就不要省了。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值