MyBatis中typealiases的使用

来源:互联网 发布:中国出生人口实时数据 编辑:程序博客网 时间:2024/05/21 00:55

以前一直体会不到typealiases的作用,今天遇到了问题!

问题描述

Mybatis有个代码生成工具,生成的代码里面有mapper.xml文件,mapper.xml中的sql语句会用parameterType这个属性,而这个值可能是我们自定义的对象,此时,如果没有typealiases,我们就需要为parameterType指定全路径:

<span style="font-size:14px;"><select id="getStudent" parameterType="com.csct.domain.StudentEntity" resultType="com.csct.domain.StudentEntity" resultMap="studentResultMap"></span>

代码自动生成工具生成的mapper.xml文件中不带全路径,那么,如果有三、四十个实体对象,我们岂不是要修改的地方太多了。

解决办法

这个时候,我们是不是很期望有一个方式,能把com.csct.domain下的实体全部给加载进来,mapper.xml遇到不识别的类就在这里查找呢?你都想到了,Mybatis当然也能想到吧,typealiases就是为此而生的。使用特简单,如下:

<span style="font-size:14px;"><configuration>    <typeAliases>      <!--      通过package, 可以直接指定package的名字, mybatis会自动扫描你指定包下面的javabean,      并且默认设置一个别名,默认的名字为: javabean 的首字母小写的非限定类名来作为它的别名。      也可在javabean 加上注解@Alias 来自定义别名, 例如: @Alias(user)       <package name="com.dy.entity"/>       -->      <typeAlias alias="UserEntity" type="com.dy.entity.User"/>  </typeAliases>    ......  </configuration></span>

这样,mapper.xml的sql语句就如下了:

<span style="font-size:14px;"><select id="getStudent" parameterType="StudentEntity" resultType="StudentEntity" resultMap="studentResultMap"></span>

哦了,完事收工~

0 0
原创粉丝点击