MyBatis 之四:结果映射和关联映射

结果映射

当查询的 SQL 中,出现了表字段名和实体类属性名不一致情况时,需要指定映射关系

常见方式:

  • 使用 SQL 的 AS 别名方式
  • ResultMap 方式
普通属性映射配置

第一步:编写结果映射

<resultMap id="empMap" type="emp"><id property="empno" column="empno"></id><result property="salary" column="sal"></result><!--如果属性名和字段名一致时,可以省略的--><result property="ename" column="ename"></result>
</resultMap>

第二步:<select>查询 中引用

<!--2.使用结果映射,就是把 resultType 换为 resultMap,注意两者不能同时使用-->
<select id="queryAll" resultMap="empMap">select empno,ename,sal,hiredate,deptno from emp
</select>

第三步:代码查询,看下不一致的属性是否能获取到值

//SqlSession
SqlSession sqlSession = MyBatisUtil.getSqlSession();
// 动态代理  动态根据接口实现生成对应的实现类的代理对象
IEmpDao dao = sqlSession.getMapper(IEmpDao.class);Emp emp = dao.get(1);dao.queryAll().forEach(System.out::println);
特别注意
autoMapping

此属性属于映射文件中 resultMap 标记

如果设置这个属性,MyBatis 将会为本结果映射开启或者关闭自动映射。

这个属性会覆盖全局的属性 autoMappingBehavior。默认值:true

如果false,只是映射在<resultMap>中配置的属性才会被映射

<resultMap id="empMap" type="emp" autoMapping="true"><id property="empno" column="empno"></id><result property="salary" column="sal"></result><!--如果属性名和字段名一致时,可以省略的--><result property="ename" column="ename"></result>
</resultMap>

如果要设置所有的结果映射中的行为策略为默认禁用自动映射,可以在配置文件中配置下面配置

autoMappingBehavior

此属性属于配置文件中的 settings 标记下的配置

指定 MyBatis 应如何自动映射列到字段或属性。 NONE 表示关闭自动映射;PARTIAL 只会自动映射没有定义嵌套结果映射的字段。 FULL 会自动映射任何复杂的结果集(无论是否嵌套)。

<settings><!--日志配置--><setting name="logImpl" value="STDOUT_LOGGING"/><setting name="autoMappingBehavior" value="NONE"/>
</settings>

注意注意

如果配置了autoMappingBehavior 为 NONE 时,会对其他没有使用结果映射的查询结果产生影响

对应没有使用结果映射,而使用 resultType 的查询,会查询结果直接为 null

例如:

配置文件中配置 :

<setting name="autoMappingBehavior" value="NONE"/>

映射文件中:

<resultMap id="empMap" type="emp"><id property="empno" column="empno"></id><result property="salary" column="sal"></result>
</resultMap><!--下面使用 resultType ,代码调用查询结果返回的 Emp 对象为 null-->
<select id="get" resultType="emp">select empno,ename,sal,hiredate from emp where empno=#{empno}
</select><!--下面使用 resultMap ,可以有正常的映射结果-->
<select id="queryAll" resultMap="empMap">select empno,ename,sal,hiredate,deptno from emp
</select>

10. 关联映射

通过一个对象的查询,可以很方便自动关联查询出其他对象

一对一

一对多

多对多

实现方式

实现方式:

  1. 内嵌查询:发起N+1查询
  2. 内嵌映射
1. 内嵌查询方式

例:通过查询员工来自动关联查询部门

  • 在员工映射文件中,配置 resultMap 中配置

    <resultMap id="empMap" type="emp" autoMapping="true"><id property="empno" column="empno"></id><result property="salary" column="sal"></result><!--如果属性名和字段名一致时,可以省略的--><result property="ename" column="ename"></result><association property="dept" column="deptno" select="com.wdzl.dao.IDeptDao.get" ></association>
    </resultMap>
    • select : 映射文件中的 id 。调用其他的查询语句的。本例中,引用了com.wdzl.dao.IDeptDao命名空间中get 查询
    • column: 查询部门时,通过deptno 的值来查询的。所以注意,在查询员工时,必须得查询出 deptno

例:通过部门关联查询员工集合

  • 修改部门映射文件

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <mapper namespace="com.wdzl.dao.IDeptDao"><resultMap id="deptMap" type="Dept"><id column="deptno" property="deptno"></id><collection property="emps" column="deptno" ofType="emp"select="com.wdzl.dao.IEmpDao.getEmpByDept"></collection></resultMap><select id="get" resultMap="deptMap">select deptno,dname from dept where deptno=#{id}</select>
    </mapper>
  • 注意:

    <collection property="emps" column="deptno" ofType="emp"

                    select="com.wdzl.dao.IEmpDao.getEmpByDept"></collection>
    • select 中 来自员工映射文件中:
    <select id="getEmpByDept" resultType="emp">select empno,ename,sal,hiredate,deptno from emp where deptno=#{id}
    </select>
    • 注意:ofType="emp"
2. 内嵌映射方式

例子:通过员工查询部门

  • 修改原有的员工查询语句,改为以员工为主的外连接查询
  • 修改结果映射 中的
<!--autoMapping="false" 内嵌映射这里默认值,这里默认不会自动映射的,需要手动配置或配置为true-->
<association property="dept"  ><id column="deptno" property="deptno"></id><result column="dname" property="dname"></result>
</association>

注意:

  • 默认情况下,autoMapping="false" 内嵌映射这里默认值

  • 这里默认不会自动映射的,需要手动配置或配置为true

  • 配置文件中影响:

    <setting name="autoMappingBehavior" value="FULL"/>

如果取值其他值 NONE 或 默认值 PARTIAL ,则 association 下不会自动映射,需要手动配置或增加属性 autoMapping="true"

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

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

相关文章

暗光增强——IAT网络推理测试(详细图文教程)

IAT模型由两个独立的分支组成&#xff0c;局部分支用于像素调整&#xff0c;并输出两个用于加法和乘法的特征图。全局分支用于全局调整并输出颜色矩阵和gamma值&#xff0c;全局分支受DETR启发&#xff0c;网络通过动态查询学习的方式更新颜色矩阵和gamma值。整个模型只有超过9…

Pytorch入门实战 P2-CIFAR10彩色图片识别

目录 一、前期准备 1、数据集CIFAR10 2、判断自己的设备&#xff0c;是否可以使用GPU运行。 3、下载数据集&#xff0c;划分好训练集和测试集 4、加载训练集、测试集 5、取一个批次查看下 6、数据可视化 二、搭建简单的CNN网络模型 三、训练模型 1、设置超参数 2、编…

脚手架原理之webpack处理html文件和模块打包

脚手架原理之webpack处理html文件和模块打包 为了更好的理解项目脚手架的使用&#xff0c;我们来学习一下webpack工具&#xff0c;因为脚手架的底层就是基于webpack工具实现的。 安装 webpack工具是基于nodejs的&#xff0c;所以首先要有nodejs环境&#xff0c;其次需要下载…

Linux学习-shell

目录 Shell: 3.Shell命令: command [-options] arg1 arg2 .. 1.Shell基本命令: 2.文件查看命令: 3.文件查找命令: 通配符: 7.压缩解压命令: 8.让虚拟机上网: 9.apt-get工具集: Shell: 1.保护Linux内核(用户和Linux内核不直接操作,通过操作Shell,Shell和内核交互) 2.命令…

【CSP试题回顾】201709-3-JSON查询

CSP-201709-3-JSON查询 解题思路 1. 初始化数据结构 map<string, string> strContent: 存储字符串类型属性的内容。键是属性名&#xff08;可能包含通过点.连接的多级属性名&#xff09;&#xff0c;值是属性的字符串值。vector<string> keyVec: 存储当前正在处…

Java基础知识总结(1)

Java概况 JavaSE是java分类中的标准版&#xff0c;是刚接触java要学习的基础知识。 JavaEE是java分类中的企业版&#xff0c;是java中的高级&#xff0c;涉及到的知识广泛。 JavaME中M是Micro的缩写&#xff0c;用在嵌入式等电子设备中。 Java软件工程师&#xff1a;通过Ja…

TongWeb+springboot部署war包失败问题

1.版本问题 关于 springboot2x 以上版本要用Tongweb6.1.7.5 以上版本 否则启动会各种报错 2.JPA冲突 TongWeb自带JPA&#xff0c;所以如果项目用的是hibernate的JPA 如:Spring Data JPA 那么就会冲突 解决方案: 找到 /TongWeb安装目录/bin 下面有个external.vimoptions文件…

Java必须掌握的遍历字符串和个数(含面试大厂题含源码)

在Java编程中&#xff0c;遍历字符串和统计字符个数是非常基础且常用的技能。下面我将介绍一些必须掌握的相关知识点和示例代码&#xff1a; 1. 字符串遍历 遍历字符串意味着逐个访问字符串中的每个字符。在Java中&#xff0c;可以使用for循环或charAt方法来实现。 使用for循…

【DAY11 软考中级备考笔记】数据结构 排序操作系统

数据结构 排序&&操作系统 3月14日 – 天气&#xff1a;晴 今天天气非常热&#xff0c;已经到20度了&#xff0c;春天已经来了。 1. 堆排序 堆排序的思想是首先建立一个堆&#xff0c;然后弹出堆顶元素&#xff0c;剩下的元素再形成一个堆&#xff0c;然后继续弹出元素&…

为什么要用scrapy爬虫库?而不是纯python进行爬虫?

为什么要用scrapy爬虫库&#xff1f;而不是纯python进行爬虫&#xff1f; Scrapy的优点Scrapy节省的工作使用纯Python编写爬虫的不足 Scrapy是一个使用Python编写的开源和协作的web爬虫框架&#xff0c;它被设计用于爬取网页数据并从中提取结构化数据。Scrapy的强大之处在于其广…

js进阶-函数参数-展开预算符-解构

一.函数参数 动态参数 剩余参数 1.1 动态参数 arguments是函数内部内置的伪数组变量&#xff0c;它包含了调用函数时传入的所有实参 function getSum() {// arguments 动态参数 只存在于 函数里面// 是伪数组 里面存储的是传递过来的实参console.log(arguments) // Argument…

自注意力机制函数(SelfAttention)python实现

Self-Attention。和Attention类似都是一种注意力机制。不同的是Attention是source对target&#xff0c;输入的source和输出的target内容不同。例如英译中&#xff0c;输入英文&#xff0c;输出中文。而Self-Attention是source对source&#xff0c;是source内部元素之间或者targ…

工科硕士研究生毕业论文撰写总结

工科硕士研究生毕业论文撰写总结 最近一段看了十几篇研究生毕业论文&#xff0c;发现不少问题。结合最近几年当评委及审论文的经验来总结下工科硕士研究生毕业论文撰写毕业论文问题与经验。 一&#xff0e;科技论文的总要求 论文是写给同行看的&#xff0c;注意读者对象。&a…

页面侧边栏顶部固定和底部固定方法

顶部固定用于侧边栏低于屏幕高度----左侧边栏 底部固定用于侧边栏高于屏幕高度----右侧边栏 vue页面方法 页面布局 页面样式&#xff0c;因为内容比较多&#xff0c; 只展示主要代码 * {margin: 0;padding: 0;text-align: center; } .head {width: 100%;height: 88px;back…

在notion里面实现四象限清单

四象限清单是一种时间管理工具&#xff0c;旨在帮助人们根据任务的重要性和紧急性来优先排序他们的工作。这个概念最早由德怀特艾森豪威尔提出&#xff0c;后来又被史蒂芬柯维在他的著作《高效能人士的七个习惯》中进一步普及。四象限清单将任务分为四个类别&#xff1a; 第一…

VueX详解

Vuex 主要应用于Vue.js中管理数据状态的一个库通过创建一个集中的数据存储&#xff0c;供程序中所有组件访问 使用场景 涉及到非父子关系的组件&#xff0c;例如兄弟关系、祖孙关系&#xff0c;甚至更远的关系组件之间的联系中大型单页应用&#xff0c;考虑如何更好地在组件外部…

洛谷 P5018 对称二叉树

题目背景 NOIP2018 普及组 T4 题目描述 一棵有点权的有根树如果满足以下条件&#xff0c;则被轩轩称为对称二叉树&#xff1a; 二叉树&#xff1b;将这棵树所有节点的左右子树交换&#xff0c;新树和原树对应位置的结构相同且点权相等。 下图中节点内的数字为权值&#xf…

计算机网络之网络层概念整理(上)

Ping背后协议的原理 Ping是一个网络工具&#xff0c;用于测试网络连接质量和设备可达性。它背后的协议是互联网控制消息协议&#xff08;Internet Control Message Protocol&#xff0c;简称ICMP&#xff09;。Ping通过发送ICMP回显请求消息给目标主机&#xff0c;并等待接收I…

window server2012 卸载iis后,远程连接黑屏

原因分析&#xff1a; 因为自己在卸载IIS的时候&#xff0c;不小心卸载了.net framework&#xff0c;系统没有了图形界面&#xff08;由完整模式Full变为了核心模式core&#xff09;&#xff0c;需要重新恢复.net framework4.5。 解决方法分析&#xff1a; 需要将核心模式co…

cool-admin node.js 实现分页 数据获取 直接框架

1.需求 获取当前的分页数据 cool有自己的封装的一套东西 2.解决 controller 注意注意注意 在这之前 配置 数据表和service Provide() CoolController({api: [],entity: BusinessOrderEntity,service: BusinessOrderService, }) /*** 获取分页数据*/Post(/page, { summary…