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 小时前
Go 语言从入门到后端项目实战完整指南
开发语言·后端·golang·go·go语言
霸道流氓气质5 小时前
Windows批处理脚本完整指南:可移植的交互式SpringBoot项目管理
windows·spring boot·后端
小杍随笔5 小时前
【Rust 工具链管理完全指南:rustup toolchain 命令实战详解】
开发语言·后端·rust
还是鼠鼠5 小时前
AI掘金头条新闻系统 (Toutiao News)-获取用户信息
后端·python·mysql·fastapi·web
BingoGo5 小时前
免费可商用 PHP 管理后台 CatchAdmin V5.3.1 发布 后台打包直降 5s 内
后端·php
JaguarJack5 小时前
免费可商用 PHP 管理后台 CatchAdmin V5.3.1 发布 后台打包直降 5s 内
后端·php·laravel
小张小张爱学习6 小时前
Spring Boot 多线程并发入门教程:ThreadPoolTaskExecutor + CompletableFuture
java·spring boot·后端
西安邮电大学6 小时前
Redis核心数据结构以及应用场景
java·redis·后端·其他·面试
AskHarries7 小时前
做 SaaS 还是做 App
后端
卷无止境7 小时前
银行里的"等不了"——SimPy Bank Renege 示例全解析
后端