原因:
- Spring 在开启事务时,会从数据库连接池获取连接
- 在 service 或 controller 中使用
@DS
或 使用DynamicDataSourceContextHolder
动态切换数据源时,mybatis-plus 只是做了一层拦截,并没有改变事务的连接 - 所以在该事务内的所有操作,都是 Spring 在之前获取的连接,动态切换就失效了
解决:
- 要想动态切换数据源生效,则需要 mybatis-plus 去获取数据库连接,所以解决办法一:去除
@Transactional
,不让 Spring 获取事务 - 使用
@Transactional(propagation = Propagation.REQUIRES_NEW)
,开启事务,且动态数据源切换生效
网友评论