框架——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不能很好的表示领域模型,就需要自己再进一步的把它转化为对应的对象,这常常在复杂查询中很有作用。

框架——Mybatis中resultType和resultMap的区别_第1张图片

二、resultType

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

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

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

三、resultMap

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

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

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

你可能感兴趣的:(mybatis,java,开发语言,后端,mybatis)