MyBatis中关于resultType和resultMap的区别

  1. 使用resultType做自动映射时,要注意字段名和POJO的属性名必须一致。
  2. 使用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>

重要区别·详解

  1. resultType直接表示返回类型,包括基础数据类型和复杂数据类型
  2. resultMap是对外部resultMap定义的引用,对应外部resultMap的id,表示返回结果到哪一个resultMap上。它的应用场景一般是:数据库字段信息与对象属性不一致或者需要做复杂的联合查询,以便自由控制映射结果。
  3. 在MyBatis进行查询映射的时候,查询出来的每个字段值都放在一个对应的Map里面,其中键是字段名,值则是其对应的值。当select元素提供的返回类型属性是resultType的时候,MyBatis会将 Map里面的键值对取出赋给resultType所指定的对象对应的属性(即调用对应的对象里的属性的setter方法进行填充)。正因为如此,当使用resultType的时候,直接在后台就能接收到其相应的对象属性值。由此可看出,其实MyBatis的每个查询映射的返回类型都是 resultMap,只是当我们提供的返回类型属性是resultType 的时候,MyBatis 会自动把对应的值赋给resultType所指定对象的属性;而当我们提供的返回类型属性是 resultMap 的时候,因为 Map不能很好地表示领域模型,就需要通过进一步的定义把它转化为对应的实体对象。

注意事项
  在MyBatis的select元素中,resultType和resultMap本质上是一样的,都是Map数据结构。但需要明确一点:resultMap和resultType属性绝对不能同时存在,只能二选一

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值