<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配置:

  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配置:

  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类源码:

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

题外话:

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

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

mybaits3.2.8 别名包扫描通配符的更多相关文章

  1. Mybatis 自定义SqlSessionFactoryBean扫描通配符typeAliasesPackage

    typeAliasesPackage 默认只能扫描某一个路径下,或以逗号等分割的 几个路径下的内容,不支持通配符和正则,采用重写的方式解决 package com.xxxx.xxx.util.comm ...

  2. spring整合mybatis错误:class path resource [config/spring/springmvc.xml] cannot be opened because it does not exist

    spring 整合Mybatis 运行环境:jdk1.7.0_17+tomcat 7 + spring:3.2.0 +mybatis:3.2.7+ eclipse 错误:class path reso ...

  3. Mybatis从认识到了解

    目录 MyBatis的介绍 介绍: 为什么选择MyBatis: 与Hibernate的对比: MyBatis的优点: 入门示例 Mybatis核心组件 四大核心组件 SqlSessionFactory ...

  4. Mybatis-spring 动态代理

    1.UserMapper.java package com.cn.mapper; import java.util.List; import com.cn.pojo.User; public inte ...

  5. Mybatis-spring 传统dao开发

    jdbc.properties jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/mybatis?chara ...

  6. ssm学习的第一个demo---crm(1)

    这是一个普通的CRM项目 (第一步规划好项目设计路线:导入jar包→配置sqlMapConfig.xml(空文件)→配置applicationContext.xml →配置springMVC.xml→ ...

  7. SpringMVC+Spring+MyBatis 整合与图片上传简单示例

    一.思路: (一) Dao层: 1. SqlMapConfig.xml,空文件即可.需要文件头.2. applicationContext_dao.xml. a) 数据库连接池b) SqlSessio ...

  8. Mybatis和Spring整合&逆向工程

    Mybatis和Spring整合&逆向工程Mybatis和Spring整合mybatis整合Spring的思路目的就是将在SqlMapConfig.xml中的配置移植到Spring的appli ...

  9. SpringMVC-Mybatis整合和注解开发

    SpringMVC-Mybatis整合和注解开发SpringMVC-Mybatis整合整合的思路在mybatis和spring整合的基础上 添加springmvc.spring要管理springmvc ...

随机推荐

  1. 向Array中添加堆排序

    堆排序思路 堆排序是一种树形选择排序方法(注意下标是从1开始的,也就是R[1...n]). 1) 初始堆: 将原始数组调整成大根堆的方法——筛选算法:比较R[2i].R[2i+1]和R[i],将最大者 ...

  2. Netsharp快速入门(之15) 销售管理(报表B 销售季度表)

    作者:秋时 杨昶   转载须说明出处 4.6.2  销售季度表(交叉表) 1.1.1.1 交叉表带数据源和不带数据源区别 带数据源的可以自定义数据源,可以从实体,也可以从Sql脚本得到数据源,并能自定 ...

  3. 学习Linux第三天

    1.常用的命令: reset 清屏 leave +hhmm 建立离开提醒 sudo apt-get yum 安装yum程序 sudo su 切换root身份 see test.c 可以直接查看文件,神 ...

  4. 博文&零散信息阅读

    关于培养方案: 全国一线高校.网易云课堂和我院培养计划的区别主要体现在: 基础课上,我院删去了物理课程的必修要求. 专业课上,删去了汇编语言.编译原理.信息安全技术等学科的必修要求. 专业选修课上,我 ...

  5. 【CentOS】Eclipse中svn插件使用

    目录: 1.安装 2.使用 3.错误 1.安装 svn插件地址: Subclipse 1.6.x Update Site - http://subclipse.tigris.org/update_1. ...

  6. Windows下配置使用MemCached

    工具: memcached-1.2.6-win32-bin.zip     MemCached服务端程序(for win) Memcached Manager             win下的Mem ...

  7. 【BZOJ】【3504】【CQOI2014】危桥

    网络流/最大流 比较裸的最大流= = 无向图上走来回其实就等价与走两遍>_> 如果路径有相交其实不影响答案的 比较恶心的是两个人路过同一座桥,但走的方向不同互相抵消流量了…… 其实只要在第 ...

  8. ubuntu 安装完成后的工作

    以安装 ubuntu 15.10 为例 1. 备份并更改源 cd /etc/apt sudo cp source.list source.list.bak sudo vi source.list 删除 ...

  9. ASP.NET 大文件上传的简单处理

    在 ASP.NET 开发的过程中,文件上传往往使用自带的 FileUpload 控件,可是用过的人都知道,这个控件的局限性十分大,最大的问题就在于上传大文件时让开发者尤为的头疼,而且,上传时无法方便的 ...

  10. 直面Javascript面试题算法思路

    一.字符串遍历类 1.获取符合条件的字符 思路:一般使用正则表达式会比遍历字符串简单.a=str.match(reg),a即为所得. 例子:a.判断字符串是否是这样组成的,第一个必须是字母,后面可以是 ...