Mybatis resultMap标签继承、复用、嵌套方式
作者:王二小丷 发布时间:2023-06-27 13:27:43
resultMap标签继承、复用、嵌套
记录演示 Mybatis 中 resultMap 标签继承、复用(包括跨文件)以及多层嵌套的使用方法,
继承: 继承已存在的 resultMap 标签进行扩展
复用: 跨mapper文件引用现存的 resultMap 标签
嵌套: 多层嵌套的JavaBean与 resultMap 映射方法
定义表与实体类
表
创建三个表 group member score
score 与 member 一对一,通过 score.id 关联
group 与 member 一对多,通过 group.id 关联
create table `score` (
? ? `id` int comment '主键',
? ? `math` float comment '数学成绩',
? ? `history` float comment '历史成绩',
? ? primary key (`id`)
)
create table `member` (
? ? `id` int comment '主键',
? ? `name` varchar comment '姓名',
? ? `group_id` int comment '所属组group表id',
? ? `score_id` int comment '成绩Score表id',
? ? primary key (`id`)
)
create table `group` (
? ? `id` int comment '主键',
? ? `name` varchar comment '组名',
? ? primary key (`id`)
)
实体类
创建三个实体类 Group Member Score
Score 类的对象是 Member 类的成员变量
Member 类的对象集合是 Group 类的成员变量
/** 成绩类 */
public class Score {
? ? private Integer id;
? ? /** 数学成绩 */
? ? private Float math;
? ? /** 历史成绩 */
? ? private Float hitory;
? ? ...getter And setter...
}
/** 成员类 */
public class Member {
? ? private Integer id;
? ? /** 姓名 */
? ? private String name;
? ? /** 分数对象 */
? ? private Score score;
? ? ...getter And setter...
}
/** 组类 */
public class Group {
? ? private Integer id;
? ? /** 组名 */
? ? private String groupName;
? ? /** 成员 */
? ? private List<Member> members;
? ? ...getter And setter...
}
定义与表映射的 resultMap
在 BeanMapper.xml 定义最基本的与数据库表字段映射的 resultMap 标签
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.BeanMapper">
? ? <!-- Score实体类映射 -->
? ? <resultMap id="scoreMap" type="com.example.Score">
? ? ? ? <id column="id" jdbcType="INTEGER" property="id" />
? ? ? ? <result column="math" jdbcType="FLOAT" property="math" />
? ? ? ? <result column="history" jdbcType="FLOAT" property="history" />
? ? </resultMap>
? ? <!-- Member实体类映射 -->
? ? <resultMap id="memberMap" type="com.example.Member">
? ? ? ? <id column="id" jdbcType="INTEGER" property="id" />
? ? ? ? <result column="name" jdbcType="VARCHAR" property="name" />
? ? </resultMap>
? ? <!-- Group实体类映射 -->
? ? <resultMap id="groupMap" type="com.example.Group">
? ? ? ? <id column="id" jdbcType="INTEGER" property="id" />
? ? ? ? <result column="name" jdbcType="VARCHAR" property="groupName" />
? ? </resultMap>
</mapper>
继承、复用、嵌套
创建 DemoMapper.xml,演示标签的继承、复用、嵌套
复用现存标签时若位于相同mapper文件可直接使用 resultMap 的 id 属性引用,跨文件时需要指定 namespace 属性才可正常引用
extends
: 继承,可继承其他 resultMap 并加以扩展association
: 复用现存的 resultMap,适用于对应的属性为单JavaBean时,使用 javaType 指定Java类型collection
: 复用现存的 resultMap,适用于对应的属性为JavaBean集合时,使用 ofType 指定Java类型columnPrefix
: 只将该属性指定前缀的属性赋值给当前 resultMap,存在多层嵌套时每进入一层就会将本层前缀截取掉。
如下面的mapper文件中,外层的 fullMemberMap 前缀为 member_,经本次筛选 member_score_id -> score_id,
内层的 scoreMap 前缀为 score_,经本次筛选 score_id -> id,最终被赋值给 Score.id
所以只有形如 member_score_id 的字段才会最终进入 scoreMap 的取值范围中
若是不复用只是单纯嵌套,则可以直接将三个类写在一个 resultMap 标签内实现
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.DemoMapper">
? ? <!-- extends: 继承 -->
? ? <resultMap id="fullMemberMap" extends="com.example.BeanMapper.memberMap" type="com.example.Member">
? ? ? ? <!-- association: 复用已存在的resultMap,单JavaBean属性时使用
? ? ? ? ? ? ? ? ? ? ? ? 使用javaType属性指定JavaBean的类型
? ? ? ? ? ? ? ? ? ? ? ? 跨文件引用需指定namespace -->
? ? ? ? <!-- columnPrefix: 只从 score_ 开头的字段为当前resultMap取值 -->
? ? ? ? <association ?property="score" resultMap="com.example.BeanMapper.scoreMap" javaType="com.example.Score" columnPrefix="score_" />
? ? </resultMap>
? ??
? ? <resultMap id="fullGroupMap" extends="com.example.BeanMapper.groupMap" type="com.example.Group">
? ? ? ? <!-- collection: 复用已存在的resultMap,JavaBean集合属性时使用
? ? ? ? ? ? ? ? ? ? ? ? 使用ofType属性指定JavaBean的类型
? ? ? ? ? ? ? ? ? ? ? ? 同文件引用无需指定namespace -->
? ? ? ? <!-- columnPrefix: 只从 member_ 开头的字段为当前resultMap取值
? ? ? ? ? ? ? ? ? ? ? ? 进入fullMemberMap内嵌套的scoreMap时前缀 member_ 会被去除,即 member_score_id 字段才能被scoreMap正确接收 -->
? ? ? ? <collection property="members" ofType="com.example.Member" resultMap="fullMemberMap" columnPrefix="member_"/>
? ? </resultMap>
? ? <!-- 直接引用最终的resultMap,并根据columnPrefix属性设置的前缀为各个字段指定不同的别名 -->
? ? <select id="selectGroupById" parameterType="java.lang.Integer" resultMap="fullGroupMap">
? ? ? ? select g.id, g.name,
? ? ? ? ? ? ? ?m.id member_id, m.name member_name,
? ? ? ? ? ? ? ?s.id member_score_id, s.math member_score_math, s.history member_score_history
? ? ? ? ? from `group` g
? ? ? ? ? ? left join `member` m on m.group_id = g.id
? ? ? ? ? ? left join `score` s on s.id = m.score_id
? ? ? ? ? where g.id = #{id,jdbcType=INTEGER}
? ? </select>
</mapper>
使用resultMap需要注意的地方
今天主要还是根据需求在进行sql的编写 ,在mybatis里面进行复查和复用的时候一定要去看所对应的有没有这个类 ,今天弄了几个dto,还有时间戳的转换,java里面的时间戳是以毫秒来进行计算的。
所以说在专用mysql的时候要注意
来源:https://blog.csdn.net/jiamaRay/article/details/108688542


猜你喜欢
- 1.Knife4j在线API文档基本使用Knife4j是一款基于Swagger 2的在线API文档框架。使用Knife4j的基础步骤:添加依
- 本文实例讲述了C#判断字符串是否存在字母及字符串中字符的替换的方法。分享给大家供大家参考。具体实现方法如下:首先要添加对命名空间“using
- 背景最近对于 Java 多线程做了一段时间的学习,笔者一直认为,学习东西就是要应用到实际的业务需求中的。否则要么无法深入理解,要么硬生生地套
- WPF实现窗体中的悬浮按钮,按钮可拖动,吸附停靠在窗体边缘。控件XAML代码:<Button x:Class="SunCre
- Java对称加密Cipher实现对称加密public class EncrypDES { // 字符串默认键值 &
- 一、Future 接口当 call()方法完成时,结果必须存储在主线程已知的对象中,以便主线程可以知道该线程返回的结果。为此,可以使用 Fu
- Java 向上转型和向下转型的详解转型是在继承的基础上而言的,继承是面向对象语言中,代码复用的一种机制,通过继承,子类可以复用父
- 安装JDK 向导进行相关参数设置。如图: 正在安装程序的相关功能,如图: 选择安装的路径,可以自定义,也可以默认路径。如图: 成功安装之
- #define只加一个参数 的解释<stdio.h> 里有:#ifndef __STDIO_H #define &n
- 实现效果:奔溃的线程侠:(单线程)主线程正在处理刷新图片的请求时,无法再接受其他请求,从而陷入阻塞的死循环状态。绘制图片import jav
- 前言A*搜寻算法俗称A星算法。这是一种在图形平面上,有多个节点的路径,求出最低通过成本的算法。常用于游戏中通过二维数组构建的一个迷宫,“%”
- WebServiceHelper代码:using Microsoft.CSharp;using System;using System.Co
- 一个简单的HelloSpringMVC程序先在web,xml中注册一个前端控制器(DispatcherServlet) <?xml v
- 一.概述在微服务框架中,一个由客户端发起的请求在后端系统中会经过多个不同的的服务节点调用来协同产生最后的请求结果,每一个前段请求都会形成一条
- 创建maven父子工程时遇到一个问题,当子工程的名称前缀和父工程的名称一样时,子工程会出现一系列的问题。比如我的父工程名称是microser
- 刚开始我以为熔断和降级是一体的,以为他们必须配合使用; 只不过名字不一样而已,但是当我经过思考过后,发现他们其实不是一个东西;降级什么是服务
- 目录前言概念什么是循环依赖?报错信息通俗版理解两人对峙必须有一人妥协Spring版理解实例化和初始化什么区别? * 缓存创建过程(简易版)创建
- 本文实例讲述了Java内部类对象的创建及hook机制。分享给大家供大家参考,具体如下:Java中的内部类虽然在状态信息上与其外围类在状态信息
- 入住博客园4年多了,一直都是看别人的博客,学习别人的知识,为各个默默无私贡献自己技术总结的朋友们顶一个;这几天突然觉得是时候加入该队列中,贡
- 由于最近想要阅读下JDK1.8 中HashMap的具体实现,但是由于HashMap的实现中用到了红黑树,所以我觉得有必要先复习下红黑树的相关