MyBatis中关于resultType和resultMap的区别
- 使用
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属性绝对不能同时存在,只能二选一
MyBatis中关于resultType和resultMap的区别相关推荐
- oracle resulttype,MyBatis中关于resultType和resultMap的区别介绍
MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,resultType是直接表示返回类型的(对应着我们的model对象中的实体),而re ...
- java中resulttype,深入理解Mybatis中的resultType和resultMap
一.概述 MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,resultType是直接表示返回类型的,而resultMap则是对外部Re ...
- 详解Mybatis中的resultType和resultMap
resultType和resultMap是Mybatis基于xml配置开发过程中sql语句所在标签的一种属性,它们的特性如下: 1. resultType:该属性是为了配置mybatis查询的返回结果 ...
- Mybatis中的resultType与resultMap区别
都可以返回一种数据类型,比如String,Long,自定义的Person类等: MyBatis的每一个查询映射的返回类型都是ResultMap,只是当我们提供的返回类型属性是resultType的时候 ...
- mysql resulttype map_Mybatis中的resultType和resultMap查询操作实例详解
resultType和resultMap只能有一个成立,resultType是直接表示返回类型的,而resultMap则是对外部ResultMap的引用,resultMap解决复杂查询是的映射问题.比 ...
- mybatis中resultType和resultMap的区别
MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap resultType是直接表示返回类型的,而resultMap则是对外部ResultM ...
- MyBatis resultType和resultMap的区别
问题表现 今天遇到个很诡异的问题,自己写了一个查询sql,发现Order变量只有部分数据有值,其他都是null,对了好久字段是不是命名错了都没发现啥问题,最后才发现是用错resultType的锅. 查 ...
- MyBatis框架学习:<select>节点中的resultType和resultMap属性
1.为什么要进行resultType或resultMap注解配置 当需要实现的数据访问是查询类型的,在<select>节点中必须配置resultType或resultMap中的某1个属性( ...
- mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
mybatis复习02,简单的增删改查 创建数据表 user_info 在项目中创建数据表对应的实体类 UserInfo.java 在pom.xml文件中引入依赖 创建核心配置文件mybatis-co ...
最新文章
- Linux下给挂载U盘或者SD卡
- Entropy of Primitive: From Sparse Representation to Visual Information Evaluation(TCSVT2015)
- CodeForces-589B(思维/排序)
- Django-启动文件的制作
- MFC开发IM-第十八篇、如何设置编辑框的内容
- qtp 连接mysql_QTP连接MySQL
- 1688API item_search_img - 按图搜索1688商品(拍立淘)
- 【matlab】clc,close,close all,clear,clear all作用
- 树莓派安装第三方操作系统
- html idv垂直居中,2011最新整理idv+css标准.doc
- python用matplotlib作图时,x轴为时间轴,如何让x轴每隔几个点显示一次?
- 极客日报:iPhone 13或有8款配色;vivo百万年薪招工程师;特斯拉新增行车记录视频紧急情况自动保存功能
- 搭建授权服务器oauth2
- 日记01 2021年5月
- C语言实现简单的电梯控制系统
- 偏序集的最大反链【二分图】
- oracle 11g新的后台进程
- Jetson Nano配置YOLOv5并实现FPS=25
- 案例分析-电影评分分析
- CF22A Second Order Statistics