当前位置: 首页 > news >正文

gradle项目多模块中主模块加载子模块中的sqlmapper文件方法

gradle项目多模块中主模块加载子模块中的sqlmapper文件方法

gradle项目多模块中主模块加载子模块中的sqlmapper文件方法

1.子模块 build.gradle
sourceSets.main.resources {
srcDirs = ["src/main/resources", "src/main/java"] // 包含Java目录下的XML文件
includes = ["**/*.xml"] // 明确包含XML文件
}

2.主模块 build.gradle
compile project(":subModel:subModel-api")
compile project(":subModel:subModel-service")
implementation project(":subModel:subModel-api")
implementation project(":subModel:subModel-service")

3.application.properties
mybatis.mapper-locations=classpath*:mybatis/myProject/*.xml, classpath*:mybatis/**/*.xml

4.多数据源配置【关键】
@Bean(name = "scooterSqlSessionFactory")
public SqlSessionFactory sentinelSqlSessionFactory(@Qualifier("scooterDataSource") DataSource dataSource) throws Exception {
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(dataSource);
bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mybatis/myProject/*.xml"));
return bean.getObject();
}


5.gradle clean build -x test --refresh-dependencies

gradle会编译失败: 使用根项目下的 gradlew
D:\git\tengxunyunNew\myProject>gradlew clean build -x test --refresh-dependencies


"classpath*:mybatis/myProject/*.xml"
"classpath:mybatis/myProject/*.xml" 区别~!

在加载SQL Mapper文件时,classpath:和classpath*:的主要区别体现在资源查找范围和加载行为上:
1. 查找范围差异
‌classpath:‌
仅从当前模块的类路径(如target/classes目录)中查找资源,且只返回第一个匹配到的资源文件。
例如配置classpath:mapper/*.xml时,若多个模块存在同名文件,只会加载第一个被扫描到的文件。‌*classpath:**‌
会递归扫描所有类路径(包括当前模块和依赖的JAR包),返回所有匹配的资源文件。
适用于需要聚合多模块资源的场景,如classpath*:mapper/**/*.xml会加载所有模块中匹配路径的XML文件。2. 性能影响
classpath*:需要遍历所有类路径,性能低于classpath:,尤其在依赖较多时差异明显。建议在明确需要跨模块加载时才使用classpath*:3. 典型应用场景
‌单一资源加载‌
使用classpath:,如指定唯一配置文件:@PropertySource("classpath:config.properties")。‌多模块资源聚合‌
使用classpath*:,例如MyBatis需加载分散在多个JAR中的Mapper文件:mybatis.mapper-locations=classpath*:mapper/*.xml。4. 注意事项
‌同名文件处理‌
classpath:可能因加载顺序导致预期外的文件被选中,而classpath*:会加载所有同名文件,需确保逻辑兼容性。
‌路径规范‌
避免在资源路径中使用通配符时混用两种前缀,可能引发不可预期的行为。
通过合理选择前缀可精准控制资源加载范围,避免因配置不当导致的文件遗漏或重复加载问题

 

http://www.hskmm.com/?act=detail&tid=6156

相关文章:

  • MCP - 使用 fastmcp 编写 Client 调用 MCP Serverr - Streamable HTTP (四)
  • 全面理解MySQL架构
  • Figma EX 125.7.5 UI原型设计
  • 基于WebSocket的命令与控制工具WSC2详解
  • LocalDateTime节日和平日在时间占比计算方法
  • JSON字符串转换List对象列表 JSONArray toJavaList
  • vue3 使用 docx-preview 预览 Word文档
  • 数据库原理-第三章——SQL
  • 啥是CPU
  • C# Avalonia 15- Animation- CodeAnimation
  • ubuntu 18.04安装mysql 8.0.41
  • Topaz Photo AI Pro 4.0.4 AI图片智能降噪(win版)
  • 阿里云基础设施 AI Tech Day AI 原生,智构未来——AI 原生架构与企业实践专场
  • 实用指南:LINUX910 CENTOS8 新建虚拟机;重设root密码/时间同步
  • 零基础学习PYthon记录
  • C++ std::unordered_set
  • 如何将一个项目同时提交到GitHub和Gitee(码云)上
  • 基于Matlab的LeNet-5车牌字符识别系统实现
  • MATLAB的交通标志牌识别实现
  • Python常见的数据结构和代码示例
  • Grafana 中文入门教程 | 构建你的第一个仪表盘
  • Gitee DevOps:中国开发者效率革命的数字引擎
  • Topaz Photo AI Pro 4.0.4 AI图片智能降噪
  • 易基因:Nat Genet/IF29:董朝斌团队ChIP-seq等揭示作物株型穗型发育调控新机制 助力表观遗传育种驯化改良(顶刊佳作)
  • Edge浏览器网页长截图
  • Python TensorFlow的CNN-LSTM-GRU集成模型在边缘物联网数据IoT电动汽车充电站入侵检测应用
  • C++多线程编程—线程控制、同步与互斥详解
  • MySQL启动失败:mysqld.log Permis 报错处理.250916
  • 源码管理—密钥硬编码问题
  • 无速度传感器交流电机的扩展Luenberger观测器