04. Mybatis的resultMap基本应用

  
  

resultMap元素是MyBatis中最重要最强大的元素。它就是让你远离90%的需要从结果集中取出数据的JDBC代码的那个东西,而且在一些情形下允许你做一些JDBC不支持的事情。事实上,编写相似于对复杂语句联合映射这些等同的代码,也许可以跨过上千行的代码。

     

ResultMap的设计就是简单语句不需要明确的结果映射,而很多复杂语句确实需要描述它们的关系。

  

你已经看到简单映射语句的示例了,但没有明确的resultMap。比如:

  
 <代码> & lt;选择id=皊electUsers”parameterType=癷nt”resultType=癶ashmap”比;
  选择id、用户名、hashedPassword
  从some_table
  在id=# {id}
  & lt;/select>  
  

这样一个语句简单作用于所有列被自动映射到HashMap的键上,这由resultType属性指定。这在很多情况下是有用的,但是HashMap不能很好描述一个领域模型。那样你的应用程序将会使用JavaBean或pojo来作为领域模型.MyBatis对两者都支持。看看下面这个JavaBean:

  
 <代码>包com.someapp.model;
  公开课用户{
  私人int id;
  私人字符串的用户名;
  私人字符串hashedPassword;
  公共int getId () {
  返回id;
  }
  公共空间setId (int id) {
  这一点。id=id;
  }
  公共字符串getUsername () {
  返回用户名;
  }
  公共空间setUsername(字符串的用户名){
  这一点。用户名=用户名;
  }
  公共字符串getHashedPassword () {
  返回hashedPassword;
  }
  公共空间setHashedPassword(字符串hashedPassword) {
  这一点。hashedPassword=hashedPassword;
  }
  } 
  

基于JavaBean的规范,上面这个类有3个属性:id、用户名和hashedPassword。这些选择语在句中会精确匹配到列名。这样的一个JavaBean可以被映射到结果集,就像映射到HashMap一样简单。

  
 <代码> & lt;选择id=" selectUsers " parameterType=癷nt”
  resultType=癱om.someapp.model.User”比;
  选择id、用户名、hashedPassword
  从some_table
  在id=# {id}
  & lt;/select>  
  

要记住类型别名是你的伙伴。使用它们你可以不用输入类的全路径比。如:

  
 <代码> & lt; !——在XML配置文件中——比;
  & lt; typeAlias类型=" com.someapp.model。用户“别名="用户"/比;
  & lt; !——在SQL映射的XML文件中——比;
  & lt;选择id=" selectUsers " parameterType=癷nt”
  resultType="用户"比;
  选择id、用户名、hashedPassword
  从some_table
  在id=# {id}
  & lt;/select>  
  

这些情况下,MyBatis会在幕后自动创建一个ResultMap,基于属性名来映射列到JavaBean的属性上。如果列名没有精确匹配,你可以在列名上使用选择字句的别名(一个标准的SQL特性)来匹配标签。比如:

  
 <代码> & lt;选择id=" selectUsers " parameterType=癷nt”resultType=坝没А北?
  选择
  user_id " id ",
  user_name为“用户名”,
  hashed_password“hashedPassword”
  从some_table
  在id=# {id}
  & lt;/select>  
  

那么如何试用外部的resultMap:

  
 <代码> & lt; resultMap id=皍serResultMap”类型=坝没А北?
  & lt; id属性==皍ser_id”/癷d”列在
  & lt;结果属性==皍ser_name”/坝没绷性?
  & lt;结果属性==癶ashed_password”/懊苈搿绷性?
  & lt;/resultMap>  
  

引用它的语句使用resultMap属性就行了(注意我们去掉了resultType属性)。比如:

  
 <代码> & lt;选择id=" selectUsers " parameterType=癷nt”
  resultMap=皍serResultMap”比;
  选择user_id、user_name hashed_password
  从some_table
  在id=# {id}
  & lt;/select>  
  
  

ReulstMap只是字段与属性之间的映射关系的集合,那么,真正的字段与属性之间的映射关系,ResultMapping (org.apache.ibatis.mapping.ResultMapping)属性映射来描述。

     

ResultMap数据结构如下:

  
 <代码>包org.apache.ibatis.mapping;
  
  进口java.util.ArrayList;
  进口java.util.Collections;
  进口java.util.HashSet;
  进口并不知道;
  进口java.util.Locale;
  进口java.util.Set;
  
  进口org.apache.ibatis.session.Configuration;/* *
  *结果映射,保存着表与对象之间的映射关系
  *
  */公开课ResultMap {//对应& lt; resultMap>的id属性
  私人字符串id;//对应& lt; resultMap>的类型属性
  私人Class<?比;类型;//对应除& lt; discriminator>元素外的所有属性映射关系
  私人List

04. Mybatis的resultMap基本应用