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属性绝对不能同时存在,只能二选一

MyBatis中关于resultType和resultMap的区别相关推荐

  1. oracle resulttype,MyBatis中关于resultType和resultMap的区别介绍

    MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,resultType是直接表示返回类型的(对应着我们的model对象中的实体),而re ...

  2. java中resulttype,深入理解Mybatis中的resultType和resultMap

    一.概述 MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,resultType是直接表示返回类型的,而resultMap则是对外部Re ...

  3. 详解Mybatis中的resultType和resultMap

    resultType和resultMap是Mybatis基于xml配置开发过程中sql语句所在标签的一种属性,它们的特性如下: 1. resultType:该属性是为了配置mybatis查询的返回结果 ...

  4. Mybatis中的resultType与resultMap区别

    都可以返回一种数据类型,比如String,Long,自定义的Person类等: MyBatis的每一个查询映射的返回类型都是ResultMap,只是当我们提供的返回类型属性是resultType的时候 ...

  5. mysql resulttype map_Mybatis中的resultType和resultMap查询操作实例详解

    resultType和resultMap只能有一个成立,resultType是直接表示返回类型的,而resultMap则是对外部ResultMap的引用,resultMap解决复杂查询是的映射问题.比 ...

  6. mybatis中resultType和resultMap的区别

    MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap resultType是直接表示返回类型的,而resultMap则是对外部ResultM ...

  7. MyBatis resultType和resultMap的区别

    问题表现 今天遇到个很诡异的问题,自己写了一个查询sql,发现Order变量只有部分数据有值,其他都是null,对了好久字段是不是命名错了都没发现啥问题,最后才发现是用错resultType的锅. 查 ...

  8. MyBatis框架学习:<select>节点中的resultType和resultMap属性

    1.为什么要进行resultType或resultMap注解配置 当需要实现的数据访问是查询类型的,在<select>节点中必须配置resultType或resultMap中的某1个属性( ...

  9. mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数

    mybatis复习02,简单的增删改查 创建数据表 user_info 在项目中创建数据表对应的实体类 UserInfo.java 在pom.xml文件中引入依赖 创建核心配置文件mybatis-co ...

最新文章

  1. Linux下给挂载U盘或者SD卡
  2. Entropy of Primitive: From Sparse Representation to Visual Information Evaluation(TCSVT2015)
  3. CodeForces-589B(思维/排序)
  4. Django-启动文件的制作
  5. MFC开发IM-第十八篇、如何设置编辑框的内容
  6. qtp 连接mysql_QTP连接MySQL
  7. 1688API item_search_img - 按图搜索1688商品(拍立淘)
  8. 【matlab】clc,close,close all,clear,clear all作用
  9. 树莓派安装第三方操作系统
  10. html idv垂直居中,2011最新整理idv+css标准.doc
  11. python用matplotlib作图时,x轴为时间轴,如何让x轴每隔几个点显示一次?
  12. 极客日报:iPhone 13或有8款配色;vivo百万年薪招工程师;特斯拉新增行车记录视频紧急情况自动保存功能
  13. 搭建授权服务器oauth2
  14. 日记01 2021年5月
  15. C语言实现简单的电梯控制系统
  16. 偏序集的最大反链【二分图】
  17. oracle 11g新的后台进程
  18. Jetson Nano配置YOLOv5并实现FPS=25
  19. 案例分析-电影评分分析
  20. CF22A Second Order Statistics

热门文章

  1. 开发集团正版小型OA办公软件系统收费标准是多少?
  2. 疾病研究:荷兰进行的51号外显因子跳跃试验中4个孩子的肌肉中发现抗肌萎缩蛋白...
  3. unity 性能优化之遮挡剔除(Occlusion Culling) 官方版
  4. 车辆智能称重管理系统是什么
  5. PAT(甲级)2019年冬季考试7-1 Good in C (20 分)
  6. sql 笔试题——各个视频的平均完播率
  7. jasypt加密器的设置原理
  8. Monkey 简介操作
  9. QQ红钻认领音乐场景体验QQ2006新功能(转)
  10. 【未解决】HP打印机如何单独安装扫描仪驱动