MyBatis的输入映射和输出映射

news2025/1/13 12:00:44

文章目录

  • 前言
  • 案例
  • 总结
  • resultMap的使用


前言

提示:这里可以添加本文要记录的大概内容:

MyBatis的输入映射和输出映射是将Java对象和数据库表的列进行映射,实现数据的自动转换。

输入映射(Parameter Mapping):是将Java对象转换为可供SQL语句执行的参数。MyBatis提供了多种方式进行输入映射,包括基本类型、Map、注解、XML映射文件等。

输出映射(Result Mapping):是将SQL查询结果映射为Java对象。MyBatis提供了多种方式进行输出映射,包括基本类型、Map、注解、XML映射文件等。其中XML映射文件是最常用的方式,可以根据列名或列索引将查询结果映射为Java对象的属性。

通过输入映射和输出映射,可以方便地完成Java对象与数据库表的转换,提高了开发效率和代码的可维护性。


提示:以下是本篇文章正文内容,下面案例可供参考

案例

po 类

public class Dept {
	private Integer deptno;
	private String dname;
	private String loc;
	// 自动生成两个构造方法、Getter/Setter/toString
}

在同main/java包中,新建mapper包,里面新建同名的一个接口,一个映射文件

映射文件的 namespace 是接口的限定名

只有查询语句有查询

在接口文件中:

List<Dept> queryAll();

对应的映射文件:

<mapper namespace="com.mybatis.mapper.DeptMapper">
<!-- 如果查询中的列名和某个po类的属性名不一致,那么我们就需要配置结果的映射 -->
		<!-- type:po类的名字 -->
	<resultMap type="Dept" id="dept">
		<!-- id标记配置的是主键列的映射关系 -->
		<id column="no" property="deptno" />
		<!-- result配置的是非主键列和属性的映射关系 -->
		<result column="name" property="dname"/>
		<result column="location" property="loc"/>
	</resultMap>

<!-- 如果查询语句中的列名和某个po类中的属性名一致,那么需要配置resultType -->
						    	<!-- dept:上面的id值 -->
    <select id="queryAll" resultMap="dept">
    	select deptno as no,dname as name,loc as location
    	from dept 
    </select>
</mapper>

测试代码:

	@Test 
	public void queryDept() {
		DeptMapper mapper = session.getMapper(DeptMapper.class);
		List<Dept> list = mapper.queryAll();
		// foreach 生成
		for (Dept dept : list) {
			System.out.println(dept);
		}
	}

在这里插入图片描述

总结

如果查询语句中的列名和某个po类中的属性名一致,那么需要配置resultType

如果查询中的列名和某个 po 类的属性名不一致,那么就需要配置结果的映射

id 标记配置的是主键列的映射关系

result 配置的是非主键列和属性的映射关系

resultMap的使用

使用resultMap的场景如下:

  1. 数据库表和Java类字段名称不一致。如果数据库表中的列名称和Java类中的属性名称不一致,可以使用resultMap来映射这两者之间的关系,避免手动转换的繁琐和容易出错。

  2. 处理复杂查询结果。如果查询结果是多表联合查询,或者需要按照特定的顺序和格式显示结果,可以使用resultMap来定制化查询结果的映射。

  3. 查询结果中包含关联对象。如果查询结果中包含了与主对象关联的其他对象,可以使用resultMap来映射出这些关联对象,方便进行对象的嵌套查询和处理。

  4. 可以提高程序性能。使用resultMap可以缓存映射规则,避免每次查询都需要重新定义映射规则的操作,从而提高程序的性能。

总之,如果需要处理一些复杂的查询结果或者需要将数据库查询结果映射到Java对象中,就可以使用resultMap。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/838782.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

从小白到大神之路之学习运维第74天-------Docker网络模型详解

第四阶段 时 间&#xff1a;2023年8月4日 参加人&#xff1a;全班人员 内 容&#xff1a; Docker网络模型详解 目录 一、环境配置 &#xff08;一&#xff09;安装docker-ce&#xff08;Linux安装Docker&#xff09; 二、Docker网络基础 &#xff08;一&#xff09;端…

Linux 创建子进程

文章目录 前言一、进程&#xff0c;线程&#xff0c;程序 区分二、创建子进程三、创建多个进程1. 获取进程号2. 循环创建多个进程 四、进程工具。1. ps 查看当前进程.2. kill 进程终止. 总结 前言 在计算机科学中&#xff0c;进程&#xff08;Process&#xff09;、线程&#…

8.5day06 框架基础--反射+注解

文章目录 反射获取类的各种信息获取类的字节码文件 注解元注解 复习redis两道算法题 摆烂了&#xff0c;不想学啦&#xff01;&#xff01;&#xff01; 反射 反射主要用来做框架; 学习内容 获取类的各种信息 第一步 加载类&#xff0c;获取类的字节码文件 第二步 获取类的…

抖音seo矩阵系统源码搭建开发详解

抖音SEO矩阵系统是一个用于提高抖音视频在搜索引擎排名的工具。如果你想开发自己的抖音SEO矩阵系统&#xff0c;以下是详细的步骤&#xff1a; 开发步骤详解&#xff1a; 确定你需要的功能和算法 抖音SEO矩阵系统包含很多功能&#xff0c;比如关键词研究、内容优化、链接建设、…

【ASP.NET MVC】使用动软(一)(9)

一、解决的问题 前文为解决数据库操作设计的 TestMysql 类&#xff0c;仅简单地封装了一个Query函数&#xff0c;代码如下&#xff1a; public class TestMysql{public static string SqlserverConnectStr "server127.0.0.1;charsetutf8;user idroot;persistsecurityin…

PLC4X踩坑记录

plc4x引起的oom 使用Jprofiler查看dump文件 由上可以看出有大量的NioEventLoop对象没有释放 PlcConnection#close 设备断连重连后导致的oom&#xff0c;看源码close方法主要是channel通道关闭。 修改NettyChannelFactory源码 plc4x设计思想是一个设备一个连接&#xff0c;…

剑指OfferII-58.左旋转字符串

剑指OfferII-58.左旋转字符串 目录 剑指OfferII-58.左旋转字符串题目描述解法一&#xff1a;字符数组解法二&#xff1a;原地反转 题目描述 字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。 请定义一个函数实现字符串左旋转操作的功能。 比如&#xff0c…

性能测试浅谈

早期的性能测试更关注后端服务的处理能力。 一个用户去访问一个页面的请求过程&#xff0c;如上图。 数据传输时间 当你从浏览器输入网址&#xff0c;敲下回车&#xff0c;开始... 真实的用户场景请不要忽视数据传输时间&#xff0c;想想你给远方的朋友写信&#xff0c;信件…

visio,word添加缺少字体,仿宋_GB2312、楷体_GB2312、方正小标宋简体等字体下载

一. 内容简介 visio,word添加缺少字体,仿宋_GB2312、楷体_GB2312、方正小标宋简体等字体下载 二. 软件环境 2.1 visio 三.主要流程 3.1 下载字体 http://www.downza.cn/ 微软官方给的链接好多字体没有&#xff0c;其他好多字体网站&#xff0c;就是给你看个样式&#xff…

JMeter(二十四)、使用吞吐量控制器实现不同的用户操纵不同的业务

一、需求 需求&#xff1a;博客系统&#xff0c;模拟用户真实行为&#xff0c;80%的用户阅读文章&#xff0c;20%的用户创建文章&#xff0c;创建文章的用户随机的删除或者修改文章。 二、脚本实现 80%的用户查看文章 20%用户创建文章 根据post_id是否能整除2&#xff0c;决…

在线课堂,视频点播,springboo+vue

springbootvue三端&#xff08;管理后台&#xff0c;教师端&#xff0c;用户端&#xff09;端可提供源码&#xff0c;可远程安装&#xff0c;需要的加微信&#xff1a; 体验地址&#xff1a;http://edu.dgrxs.com/ 用户端&#xff1a; 管理端&#xff1a; 教师端&#xff1a;

IDEA中怎么使用git下载项目到本地,通过URL克隆项目(giteegithub)

点击 新建>来自版本控制的项目 点击后会弹出这样一个窗口 通过URL拉取项目代码 打开你要下载的项目仓库 克隆>复制 gitee github也是一样的 返回IDEA 将刚刚复制的URL粘贴进去选择合适的位置点击克隆 下载完成

三星进军机器人市场?特斯拉首款人形机器人“擎天柱”明年上市

根据报道&#xff0c;三星电子正在积极研究进军机器人市场的战略。此战略由三星电子的Device eXperience&#xff08;DX&#xff09;部门的专业企划小组制定。据可靠消息透露&#xff0c;该企划小组已着手制定相关计划&#xff0c;以推动公司在机器人市场的发展。 根据外媒报道…

危大工程智慧工地源码,微服务+Java+Spring Cloud +UniApp +MySql 物联网、人工智能、视频AI分析

一套智慧工地管理平台源码&#xff0c;PC端移动APP端可视货数据管理端源码 智慧工地可视化系统利用物联网、人工智能、云计算、大数据、移动互联网等新一代信息技术&#xff0c;通过工地中台、三维建模服务、视频AI分析服务等技术支撑&#xff0c;实现智慧工地高精度动态仿真&a…

【docker】docker私有仓库

目录 一、说明二、私有仓库搭建三、上传镜像到私有仓库四、从私有仓库拉取镜像 一、说明 1.docker官方的docker hub(https://hub.docker.com)是一个用于管理公共镜像的仓库&#xff0c;可以从上面拉取镜像到本地&#xff0c;也可以把自己的镜像推送上去 2.若服务器无法访问互联…

牵着她——表白不成功算我输(Python实现)

目录 1 牵着她的手一直走下去 2 一首小情诗送给甜甜的她 3 历史总结的哲学想法 4 表白不成功算我输&#xff08;Python代码&#xff09; 1 牵着她的手一直走下去 今天牵着她的手&#xff0c;她很贴心。一起并肩赏樱花&#x1f338;。骑着快车&#xff0c;清风抚摸着我俩的…

消息队列项目(2)

我们使用 SQLite 来进行对 Exchange, Queue, Binding 的硬盘保存 对 Message 就保存在硬盘的文本中 SQLite 封装 这里是在 application.yaml 中来引进对 SQLite 的封装 spring:datasource:url: jdbc:sqlite:./data/meta.dbusername:password:driver-class-name: org.sqlite.…

MySQL索引3——Explain关键字和索引优化(SQL提示、索引失效、索引使用规则)

目录 Explain关键字 索引性能分析 Id ——select的查询序列号 Select_type——select查询的类型 Table——表名称 Type——select的连接类型 Possible_key ——显示可能应用在这张表的索引 Key——实际用到的索引 Key_len——实际索引使用到的字节数 Ref ——索引命…

安捷伦54642D混合信号示波器

安捷伦54642D混合信号示波器 附加功能: 带宽:500兆赫&#xff08;131---4587---6435&#xff09; 通道:2个模拟和16个数字 采样速率:2Gs/s 记录长度:8分钟 获得专利的高清显示系统 灵活触发&#xff0c;包括CAN、I2C、LIN、SPI和USB 接口总线上的深层存储器传输 强大、灵活的触…

嵌入式笔试面试刷题(day5 IIC详解)

文章目录 前言一、IIC需要几根线分别是什么线二、IIC优势三、IIC可以挂载多少个从设备&#xff0c;主设备1.从设备数量2.主设备数量 四、IIC是全双工还是半双工五、SDA和SCL为什么配置为上拉开漏输出模式1.为什么要配置为开漏输出不能是推挽输出a.实现线与功能b.保护设备不会被…