- 使用
resultType
做自动映射时,要注意字段名和POJO的属性名必须一致。 - 使用
resultType
做自动映射时,可以不一致。但是你要想不一致。那么就必须在<mapper>
标签下,添加<resultMap>
标签,给需要给字段名起别名,保证别名与属性名一致。具体操作如下:
<!-- 第一步 -->
<!-- id 为 实现类取的别名 type 为 你要给某个实现类取别名 -->
<resultMap id="User" type="domain.User">
<!-- property 为实现类的属性名 column 为数据库字段名 -->
<result property="price" column="price"/>
</resultMap>
<!-- 第二步 -->
<!-- 在下面查询语句处。将resultType修改成resultMap。对应的值,就是上面对应的别名 -->
<select id="xxx" resultMap="User">
...
</select>
重要区别·详解
- resultType直接表示返回类型,包括基础数据类型和复杂数据类型
- resultMap是对外部resultMap定义的引用,对应外部resultMap的id,表示返回结果到哪一个resultMap上。它的应用场景一般是:数据库字段信息与对象属性不一致或者需要做复杂的联合查询,以便自由控制映射结果。
- 在MyBatis进行查询映射的时候,查询出来的每个字段值都放在一个对应的Map里面,其中键是字段名,值则是其对应的值。当select元素提供的返回类型属性是resultType的时候,MyBatis会将 Map里面的键值对取出赋给resultType所指定的对象对应的属性(即调用对应的对象里的属性的setter方法进行填充)。正因为如此,当使用resultType的时候,直接在后台就能接收到其相应的对象属性值。由此可看出,其实MyBatis的每个查询映射的返回类型都是 resultMap,只是当我们提供的返回类型属性是resultType 的时候,MyBatis 会自动把对应的值赋给resultType所指定对象的属性;而当我们提供的返回类型属性是 resultMap 的时候,因为 Map不能很好地表示领域模型,就需要通过进一步的定义把它转化为对应的实体对象。
注意事项
在MyBatis的select元素中,resultType和resultMap本质上是一样的,都是Map数据结构。但需要明确一点:resultMap和resultType属性绝对不能同时存在,只能二选一