框架——Mybatis中resultType和resultMap的区别

一、区别简述

1、Mybatis的结果集是通过反射实现的;

2、MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,resultType是直接表示返回类型(基础类型、包装类型),而resultMap则是对外部ResultMap的引用,resultType和resultMap不能同时存在;

3、resultMap可以自定义表字段和实体类对应关系,表的字段名和实体类的属性名不一样也会映射出来。resultType返回包装类型时,实体类的属性名和查询结果的字段要对应的上,否则对应不上的属性接收不到查询结果;

4、Mybatis进行查询映射时,查询出来的每一个属性都是放在一个对应的Map里面,其中键是属性名,值则是其对应的值。

(1)当提供的返回值类型属性是resultType时,Mybatis会将Map里面的键值对取出赋给resultType所指定的对象对应的属性,所以其实Mybatis的每一个查询映射的返回值类型都是resultMap。

(2)当提供的返回值类型是resultMap时,因为Map不能很好的表示领域模型,就需要自己再进一步的把它转化为对应的对象,这常常在复杂查询中很有作用。

二、resultType

返回类型:自定义 JavaBean、使用 mybatis 内置 或 jdk 自带的类型、容器;

应用场景:统计查询、单字段查询、表字段与实体类属性名一致情况下查询;

特殊情况:表字段与实体类属性名称不一致时,可通过在sql语句中给查询出来的字段重命名;

三、resultMap

返回类型:resultMap自定义类型;

应用场景:表字段与实体类属性名不一致情况下查询、多表联合查询;

特殊情况:多表联合查询可能出现查询出的字段有重复;

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值