MyBatis:resultMap详解

简介:  

  MyBatis的每一个查询映射的返回类型都是ResultMap,只是当我们提供的返回类型属性是resultType的时候,MyBatis对自动的给我们把对应的值赋给resultType所指定对象的属性,而当我们提供的返回类型是resultMap的时候,将数据库中列数据复制到对象的相应属性上,可以用于复制查询,两者不能同时用。

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

首先来说一下resultType

  1、使用resultType进行输出映射,只有查询出来的列名和pojo(实体bean)中的属性名一致,该列才可以映射成功。

  2、简单来说也就是你的数据库字段和JavaBean里的字段名称必须一致才能映射成功。

  3、所以当我们JavaBean中的字段名和数据库字段名称有不同的时候,或者是多表查询的时候,一般会使用resultMap

resultMap

  resultMap是Mybatis最强大的元素,它可以将查询到的复杂数据(比如查询到几个表中数据)映射到一个结果集当中。

resultMap里的子标签:

constructor:表示映射后如何实例化类,指出类中的构造方法。
id:表示主键映射。
result:表示非主键映射。
association:关联映射。
collection:表示集合映射。
discriminator:鉴别器。

resultMap里子标签的属性:

property:需要映射到JavaBean 的属性名称。

column:数据表的列名或者标签别名。

javaType:一个完整的类名,或者是一个类型别名。如果你匹配的是一个JavaBean,那MyBatis 通常会自行检测到。然后,如果你是要映射到一个HashMap,那你需要指定javaType 要达到的目的。

jdbcType:数据表支持的类型列表。这个属性只在insert,update 或delete 的时候针对允许空的列有用。JDBC 需要这项,但MyBatis 不需要。如果你是直接针对JDBC 编码,且有允许空的列,而你要指定这项。

typeHandler:使用这个属性可以覆写类型处理器。这项值可以是一个完整的类名,也可以是一个类型别名。

元素简介:

 

案例示例:

首先我们数据库中的表结构如下:

公告表:

管理员表

表字段中很多字段内如果有下划线,而我们的JavaBean里面的命名是按照驼峰规则命名的,你可在配置文件中的驼峰规则关闭:如下:

<settings>
        <setting name="mapUnderscoreToCamelCase" value="false"/>
</settings>

 一、单表查询:(查询所有公告信息)

公告信息实体类(get和set方法要放进去)

affiche_mapper.xml:

<select/>标签中使用的动态sql上章节已经说过了,这里就不说了。

affiche接口:

Dao测试:查询afficheid为5的数据

 结果:(log4j日志中)

在log4j日志中可以看到拼接成的sql语句,如下:

 

 二、一对一  多表查询(根据公告id查询公告信息并带出公告所属管理员信息):

这里引出了association联合:

  联合元素用来处理“一对一”的关系。需要指定映射的Java实体类的属性,属性的javaType(通常MyBatis 自己会识别)。

association属性:
columnPrefix:表示列的前缀,就相当于查询时对表定义了别名,在字段名前使用的别名
fetchType:加载数据方式
foreignColumn:外键列
notNullColumn:不为null的列
resultMap:结果集映射
resultSet:结果集
select:表示一个查询

affiche信息实体类(实体里面就需要添加一个管理员的成员变量)

affiche接口:

affiche_mapper.xml:

 

< association/>标签中的property属性值对应的是affiche实体中,就是我刚刚添加的成员变量,resultMap映射的是manager_mapper.xml文件中resultMap,如下:

测试:

结果:

 三、一对多  多表查询(根据管理员id或者管理员账号,查询管理员信息,并且查询出管理员所发表的所有公告信息):

首先在管理员中创建一个保存公告的集合,因为一个管理员不可能只发表一条公告。

这个时候就要用Collection在Mapper文件中进行映射。

manager实体类:

manager接口:

manager_mapper.xml文件:

 测试:

 

 结果:(log4j )

2条

四、多对多 多表查询

多对多将在后面示例说明(根据订单号 查询订单,查询出所属用户,并且查询出订单的详情,及订单详情中的对应的商品信息   订单详情和商品为多对多关系)。

未完待续

原文地址:https://www.cnblogs.com/xss512/p/10889532.html