【MyBatis-Plus 动态数据源的默认行为】

MyBatis-Plus 动态数据源的默认行为

MyBatis-Plus 动态数据源的默认行为

在代码中切换数据源到qixiang数据库,但是在yml配置信息中,注释掉qixiang数据库的配置信息,发现默认调用了配置的master数据库。


代码仍可以正常进行,并且查询了master数据库中的数据。

可能的原因分析:

  1. 默认的主数据源行为
    虽然您的配置中没有显式设置 primary: master,但动态数据源组件可能会:

将第一个定义的数据源(master)作为默认数据源

当找不到指定数据源时,使用第一个数据源作为回退

  1. 版本特定的默认行为
    不同版本的 MyBatis-Plus 动态数据源可能有不同的默认 strict 设置。

建议添加明确配置:

为了确保行为可预测,建议添加明确的配置:

详细配置信息:

bash 复制代码
spring:
  datasource:
    dynamic:
      primary: master # 明确指定主数据源
      strict: false   # 明确设置宽松模式
      druid:
        # ... 现有的druid配置
      datasource:
        master:
          # ... 现有配置
        yushuiqing:
          # ... 现有配置
        # qixiang:  # 注释掉的数据源

结论:

您的配置能够回退到 master 数据库的原因可能是:

MyBatis-Plus 动态数据源组件的默认行为:在某些版本中,当 strict 未明确设置时,默认可能是 false

顺序依赖:master 作为第一个定义的数据源被用作默认回退

推荐做法:还是建议添加明确的 primary 和 strict 配置,这样代码的行为会更加明确和可维护。

相关推荐
XiYang-DING12 小时前
【Java EE】CAS(Compare And Swap)
java·开发语言·java-ee
OneT1me12 小时前
CVE-2026-31431 的C语言版本
c语言·开发语言·安全威胁分析
白露与泡影12 小时前
Spring Boot 完整流程
java·spring boot·后端
空中海12 小时前
第二章:Maven进阶篇 — 依赖管理与构建生命周期
java·maven
xun-ming12 小时前
AI时代Java程序员自救手册
java·开发语言·人工智能
DavidSoCool12 小时前
GB28181 PTZCmd 完整指令对照表(8 位 16 进制)+ 详细注释 + 使用说明
java·sip·gb28181
张健115640964812 小时前
C++访问控制与友元
java·开发语言·c++
Sam_Deep_Thinking12 小时前
中小团队需要一个资源微服务
java·微服务·架构
Thanks_ks12 小时前
透过 Copy-On-Write 机制:理解并发编程中的性能与一致性权衡
java·多线程·并发编程·底层原理·写时复制·copyonwrite·性能优
2zcode13 小时前
基于MATLAB改进最大熵法的大规模新能源并网概率潮流计算
开发语言·matlab