mybaits3.2.8 别名包扫描通配符

简介: 3.2.81.2.21.3.2 MBG http://www.mybatis.org/spring/apidocs/reference/org/mybatis/spring/SqlSessionFactoryBean.html   这几天搭建了spring4.1.2+mybatis3.2.8一个简单的框架。
<mybatis.version>3.2.8</mybatis.version>
<mybatis.spring.version>1.2.2</mybatis.spring.version>
<mybatis.generator.version>1.3.2</mybatis.generator.version>

MBG

http://www.mybatis.org/spring/apidocs/reference/org/mybatis/spring/SqlSessionFactoryBean.html

 

这几天搭建了spring4.1.2+mybatis3.2.8一个简单的框架。

 

发现mybatis的SqlSessionFactoryBean可以配置typeAliasesPackage属性,自动为domain起别名。

 

如果我的domain在不同包下面,那么这个配置不支持通配符扫描包路径?如下改造:

 

改造前:applicationContext.xml配置:

 

[html]  view plain  copy
 
  1. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  2.     <property name="dataSource" ref="dataSource" />  
  3.     <property name="configLocation" value="classpath:/SqlMapConfig.xml"></property>  
  4.     <property name="mapperLocations" value="classpath*:/sqlmaps/**/*-sql.xml"></property>  
  5.     <property name="typeAliasesPackage" value="com.demo.domain" />  
  6. </bean>  


改造后:applicationContext.xml配置:

 

 

[html]  view plain  copy
 
  1. <bean id="sqlSessionFactory" class="com.demo.core.mybatis.TQSqlSessionFactoryBean">  
  2.     <property name="dataSource" ref="dataSource" />  
  3.     <property name="configLocation" value="classpath:/SqlMapConfig.xml"></property>  
  4.     <property name="mapperLocations" value="classpath*:/sqlmaps/**/*-sql.xml"></property>  
  5.     <property name="typeAliasesPackage" value="com.demo.**.domain" />  
  6. </bean>  


com.demo.core.mybatis.TQSqlSessionFactoryBean类源码:

 

 

[java]  view plain  copy
 
  1. package com.demo.core.mybatis;  
  2.   
  3. import java.io.File;  
  4. import java.io.IOException;  
  5.   
  6. import org.mybatis.spring.SqlSessionFactoryBean;  
  7. import org.slf4j.Logger;  
  8. import org.slf4j.LoggerFactory;  
  9. import org.springframework.core.io.Resource;  
  10. import org.springframework.core.io.support.PathMatchingResourcePatternResolver;  
  11. import org.springframework.core.io.support.ResourcePatternResolver;  
  12.   
  13. import com.demo.core.utils.StringUtil;  
  14.   
  15. /** 
  16.  * @ClassName: TQSqlSessionFactoryBean 
  17.  * @Description: mybatis自动扫描别名路径(新增通配符匹配功能) 
  18.  * @author wangxiaohu wsmalltiger@163.com 
  19.  * @date 2014年12月9日 上午9:36:23 
  20.  */  
  21. public class TQSqlSessionFactoryBean extends SqlSessionFactoryBean {  
  22.     Logger logger = LoggerFactory.getLogger(getClass());  
  23.     private static final String ROOT_PATH = "com" + File.separator + "demo"  
  24.             + File.separator;  
  25.     private static final String ROOT_PATH_SPLIT = ",";  
  26.     private static final String[] PATH_REPLACE_ARRAY = { "]" };  
  27.   
  28.     public void setTypeAliasesPackage(String typeAliasesPackage) {  
  29.         if (!StringUtil.isStringAvaliable(typeAliasesPackage)) {  
  30.             super.setTypeAliasesPackage(typeAliasesPackage);  
  31.             return;  
  32.         }  
  33.         ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();  
  34.         StringBuffer typeAliasesPackageStringBuffer = new StringBuffer();  
  35.         try {  
  36.             for (String location : typeAliasesPackage.split(",")) {  
  37.                 if (!StringUtil.isStringAvaliable(location)) {  
  38.                     continue;  
  39.                 }  
  40.                 location = "classpath*:"  
  41.                         + location.trim().replace(".", File.separator);  
  42.                 typeAliasesPackageStringBuffer.append(getResources(resolver,  
  43.                         location));  
  44.             }  
  45.         } catch (IOException e) {  
  46.             logger.error(e.getMessage(), e);  
  47.         }  
  48.         if ("".equals(typeAliasesPackageStringBuffer.toString())) {  
  49.             throw new RuntimeException(  
  50.                     "mybatis typeAliasesPackage 路径扫描错误!请检查applicationContext.xml@sqlSessionFactory配置!");  
  51.         }  
  52.         typeAliasesPackage = replaceResult(  
  53.                 typeAliasesPackageStringBuffer.toString()).replace(  
  54.                 File.separator, ".");  
  55.         super.setTypeAliasesPackage(typeAliasesPackage);  
  56.     }  
  57.   
  58.     private String getResources(ResourcePatternResolver resolver,  
  59.             String location) throws IOException {  
  60.         StringBuffer resourcePathStringBuffer = new StringBuffer();  
  61.         for (Resource resource : resolver.getResources(location)) {  
  62.             String description = resource == null ? "" : resource  
  63.                     .getDescription();  
  64.             if (!StringUtil.isStringAvaliable(resource.getDescription())  
  65.                     || description.indexOf(ROOT_PATH) == -1) {  
  66.                 continue;  
  67.             }  
  68.             resourcePathStringBuffer.append(  
  69.                     description.substring(description.indexOf(ROOT_PATH)))  
  70.                     .append(ROOT_PATH_SPLIT);  
  71.         }  
  72.         return resourcePathStringBuffer.toString();  
  73.     }  
  74.   
  75.     private String replaceResult(String resultStr) {  
  76.         for (String replaceStr : PATH_REPLACE_ARRAY) {  
  77.             resultStr = resultStr.replace(replaceStr, "");  
  78.         }  
  79.         return resultStr;  
  80.     }  
  81. }  

 

 

题外话:

typeAliasesPackage配置路径下的domain中可以添加@org.apache.ibatis.type.Alias(value = "user")注解;如果添加此注解,则别名使用此注解所指定的名称。如果没有配置,则默认为类名首字母小写。

http://blog.csdn.net/wsmalltiger/article/details/41825375

 

相关文章
|
2月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
8月前
|
Java
SpringBoot 映射路径中 匹配正则表达式
SpringBoot 映射路径中 匹配正则表达式
213 0
|
SQL PHP
【ThinkPHP】like同一个字段多个条件查询
【ThinkPHP】like同一个字段多个条件查询
708 0
【ThinkPHP】like同一个字段多个条件查询
通配符注意事项
通配符注意事项
84 0
|
PHP 数据库
thinkphp 获取数据库中的表名并去除黑名单
thinkphp 获取数据库中的表名并去除黑名单
98 0
|
Java Spring
Spring配置详解,别名和导入
1.别名 例如:给hello取一个别名叫hey:
226 1
|
Java
java中正规的项目包结构:域名倒序.项目名称.模块名称.类名
java中正规的项目包结构:域名倒序.项目名称.模块名称.类名
181 0
java中正规的项目包结构:域名倒序.项目名称.模块名称.类名
|
数据库
《Drools7.0.0.Final规则引擎教程》番外实例篇——获取规则名称和包名
《Drools7.0.0.Final规则引擎教程》番外实例篇——获取规则名称和包名
231 0
|
数据格式 XML Java
sqlSessionFactoryBean.setMapperLocations 通配符 在配置代码中怎样使用
sqlSessionFactoryBean.setMapperLocations 通配符 在配置代码中怎样使用 @Bean(name = ["sqlSessionFactoryMicrotek"]) @Primary @Thr...
9619 0