美文网首页
MyBatis-Plus 多数据源动态切换不生效

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

作者: nesanero | 来源:发表于2022-12-13 19:35 被阅读0次

    原因:

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

    解决:

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

    相关文章

      网友评论

          本文标题:MyBatis-Plus 多数据源动态切换不生效

          本文链接:https://www.haomeiwen.com/subject/vszhqdtx.html