我们在哪里使用resultMap?
resultMap是做什么的
resultMap是对外部resultMap定义的引用,对应外部resultMap的id,表示返回结果映射到哪一个resultMap上。它的应用场景一般是:数据库字段信息与对象属性不一致或者需要做复杂的联合查询以便自由控制映射结果。
最开始我们用的是resultType,它和resultType有什么关联和区别呢
resultType直接表示返回类型,包括基础数据类型和复杂数据库类型。
在MyBatis进行查询映射的时候,其实查询出来的每个字段值都放在一个对应的 Map里面,其中键是字段名,值则是其对应的值。当selet元素提供的返回类型属性是resultType的时候,MyBais会将Map里面的键值对取出赋给resultType所指定的对象对应的属性(即调用对应的对象里的属性的setter 方法进行填充)。正因为如此,当使用resultType 的时候,直接在后台就能接收到其相应的对象属性值。由此可看出,其实MyBatis的每个查询映射的返回类型都是resultMap.只是当我们提供的返回类型属性是resultType的时候,MyBatis会自动把对应的值赋给resultType所指定对象的属性:而当我们提供的返回类型是resultMap的时候,因为Map不能很好地表示领域模型,我们就需要通过进一步的定义把它转化为对应的实体对象。
当返回类型是resultMap时,也是非常有用的,这主要用在进行复杂联合查询上,当然在进行简单查询时是没有什么必要的,使用rsultType 足以。
在MyBatis的selet元素中, rsulType和resultMap 本质上是一样的,都是Map数据结构。但需要明确一点: rsultype 属性和rsutMla属性绝对不能同时存在,只能二者选其一使用。
resultMap的自动映射级别
resultMap的映射级别有:
- NONE:禁止自动匹配;
- PARTIAL(默认):自动匹配所有属性,有内部嵌套(association、collection)的除外;
- FULL:自动匹配所有。
resultMap默认的映射级别为PARTIAL。默认映射级别下,若字段名与属性名一致,即使没有做属性名和字段名的匹配,也可以正确查询到数据。
如何设置resultMap的映射级别
<settings>
<!-- 设置resultMap的自动映射级别为FULL(自动匹配所有) -->
<setting name="autoMappingBehavior" value="FULL"/>
</settings>