MyBatis-Plus 多数据源动态切换不生效

2022-12-13  本文已影响0人  nesanero

原因:

  1. Spring 在开启事务时,会从数据库连接池获取连接
  2. 在 service 或 controller 中使用 @DS 或 使用 DynamicDataSourceContextHolder 动态切换数据源时,mybatis-plus 只是做了一层拦截,并没有改变事务的连接
  3. 所以在该事务内的所有操作,都是 Spring 在之前获取的连接,动态切换就失效了

解决:

  1. 要想动态切换数据源生效,则需要 mybatis-plus 去获取数据库连接,所以解决办法一:去除 @Transactional,不让 Spring 获取事务
  2. 使用 @Transactional(propagation = Propagation.REQUIRES_NEW),开启事务,且动态数据源切换生效
上一篇 下一篇

猜你喜欢

热点阅读