Mybaitis 项目多模块多依赖xml加载classpath:和classpath*:的区别

核心结论

  • classpath: :仅在当前模块的类路径中查找资源。
  • classpath*: :在所有模块(包括依赖的JAR包)的类路径中递归查找资源。
  • 多模块项目必须使用 classpath*:

详细对比

特性 classpath: classpath*:
查找范围 仅限当前应用或模块的类路径(如 src/main/resources)。 当前类路径 + 所有依赖JAR包的类路径。
适用场景 单体应用,所有资源文件都在本项目内。 多模块/微服务项目,或依赖第三方JAR包中含有资源文件。
多模块结果 无法扫描到依赖子模块JAR包中的Mapper文件,导致 Invalid bound statement错误。 能正确扫描并加载所有依赖模块中的Mapper文件。
性能 相对更快(搜索范围小)。 相对稍慢(搜索范围广,通常影响可忽略)。

配置示例

在Spring Boot的 application.yml中,多模块项目应如下配置:

yaml 复制代码
mybatis:
  mapper-locations: classpath*:mapper/**/*.xml

重要补充说明

  1. 路径通配符

    • **/*.xml:匹配任意深度的子目录。
    • *.xml:仅匹配当前目录,不进入子目录。
  2. 最佳实践

    • 无脑推荐:在多模块项目中,MyBatis的 mapper-locations统一使用 classpath*:前缀。

    • 若追求极致精确,可指定具体路径(需了解依赖JAR内结构):

      yaml 复制代码
      mybatis:
        mapper-locations: classpath*:com/yourcompany/**/mapper/*.xml
  3. 常见错误 :在聚合模块中使用 classpath:导致启动失败,提示绑定语句找不到。首要检查点就是将此配置改为 classpath*:

相关推荐
葫芦和十三5 小时前
图解 MongoDB 02|BSON:你以为存的是 JSON,其实是带类型的二进制
后端·mongodb·agent
葫芦和十三5 小时前
图解 MongoDB 01|文档数据库
后端·mongodb·agent
陈随易7 小时前
VSCode的Copilot扩展支持接入DeepSeek,Kimi了!
前端·后端·程序员
我不是外星人9 小时前
有了 Harness Engineering ,真的还需要研发工程师吗?
前端·后端·ai编程
candyTong9 小时前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
Rust研习社11 小时前
组合真的优于继承吗?为什么 Rust 和 Go 都拥抱组合舍弃继承?
后端·rust·编程语言
IT_陈寒11 小时前
JavaScript的闭包把我坑惨了,说好的内存会自动回收呢?
前端·人工智能·后端
CaffeinePro12 小时前
Pydantic深度使用:数据校验、枚举、ORM映射
后端·fastapi
Chenyiax13 小时前
从 Chat 到 Responses:OpenAI API 抽象为什么变了?
后端
MariaH13 小时前
Koa和Express的区别
后端