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*:会加载所有同名文件,需确保逻辑兼容性。
路径规范
避免在资源路径中使用通配符时混用两种前缀,可能引发不可预期的行为。
通过合理选择前缀可精准控制资源加载范围,避免因配置不当导致的文件遗漏或重复加载问题