Mybatis简介
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。
MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。
MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录
问题
Spring集成Mybatis的项目中,可以为指定包下的实体取别名,这样在Mapper xml文件中可以省略实体类的全路径名称,只写类名称即可;但是在多模块项目中,可能需要将实体放在不同的模块下,此时需要配置多路径扫描;
方式一:配置多个路径,逗号分隔符隔开
<!-- sqlSessionFactory spring 整合 mybatis -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<!-- mybatis 核心配置 -->
<property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
<!-- mapper xml -->
<property name="mapperLocations">
<array>
<value>classpath*:mybatis/mapper
public class SqlSessionFactoryBean extends org.mybatis.spring.SqlSessionFactoryBean {
public static final Logger logger = LoggerFactory.getLogger(SqlSessionFactoryBean.class);
public static final String DEFAULT_RESOURCE_PATTERN = "**
@Override
public void setTypeAliasesPackage(String typeAliasesPackage) {
// 资源路径解析器
ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
// 元数据读取
MetadataReaderFactory metadataReaderFactory = new CachingMetadataReaderFactory(resolver);
// 解析路径
typeAliasesPackage = ResourcePatternResolver.CLASSPATH_ALL_URL_PREFIX + ClassUtils.convertClassNameToResourcePath(typeAliasesPackage) + "/" + DEFAULT_RESOURCE_PATTERN;
logger.debug("别名包通配符:" + typeAliasesPackage);
try {
Set<String> result = new HashSet<>(); // 别名包路径集合
Resource[] resources = resolver.getResources(typeAliasesPackage); // 根据路径 读取所有的类资源
if (resources != null && resources.length > 0) {
MetadataReader metadataReader = null;
for (Resource resource : resources) {
if (resource.isReadable()) {
metadataReader = metadataReaderFactory.getMetadataReader(resource); // 读取类的信息,每个 Resource 都是一个类资源
try {
result.add(Class.forName(metadataReader.getClassMetadata().getClassName()).getPackage().getName()); // 存储类对应的包路径
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
}
if (result.size() > 0) {
logger.debug("别名包路径集合:" + StringUtils.join(result.toArray(), ","));
super.setTypeAliasesPackage(StringUtils.join(result.toArray(), ","));
} else {
logger.warn("Parameter typeAliasesPackage:" + typeAliasesPackage + ", not found any packages.");
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
Xml配置:
<!-- sqlSessionFactory 采用自定义的 -->
<bean id="sqlSessionFactory" class="com.dongzz.cms.common.plugin.mybatis.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<!-- mybatis 核心配置 -->
<property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/>
<!-- mapper xml -->
<property name="mapperLocations">
<array>
<value>classpath*:mybatis/mapper/*.xml</value>
</array>
</property>
<!-- 实体类别名 通配符扫描 -->
<property name="typeAliasesPackage" value="com.dongzz.cms.modules.**.entity" />
</bean>
通过自定义 SqlSessionFactoryBean
使得mybatis支持通配符别名扫描,这样在多模块项目中,扫描路径仅需要配置一次即可;
到此这篇关于Mybatis实体别名支持通配符扫描的文章就介绍到这了,更多相关Mybatis通配符扫描内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!