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*:

相关推荐
azhou的代码园39 分钟前
基于SpringBoot+微信小程序的图片识别科普系统
spring boot·后端·微信小程序
Tony Bai1 小时前
Rust 看了流泪,AI 看了沉默:扒开 Go 泛型最让你抓狂的“残疾”类型推断
开发语言·人工智能·后端·golang·rust
用户3167361303421 小时前
javaLangchain4j从官方文档入手,看他做了什么——具体使用(二)
后端
無名路人1 小时前
Zsh 脚本 + VS Code 任务:NestJS + Vue3 一键部署到 1Panel
运维·后端·自动化运维
ybwycx2 小时前
springboot之集成Elasticsearch
spring boot·后端·elasticsearch
程途知微2 小时前
AQS 同步器——Java 并发框架的核心底座全解析
java·后端
iPadiPhone3 小时前
分布式架构的“润滑剂”:RabbitMQ 核心原理与大厂面试避坑指南
分布式·后端·面试·架构·rabbitmq
武子康3 小时前
大数据-255 离线数仓 - Apache Atlas 数据血缘与元数据管理实战指南
大数据·后端·apache hive
javaTodo3 小时前
IntelliJ IDEA 2026.1 上强度了:Spring 运行时 Debug + AI 全面接入,太香了
后端
晴栀ay4 小时前
Generator + RxJS 重构 LLM 流式输出的“丝滑”架构
javascript·后端·llm