mybatis深入讲解resultMap的定义及用法

目录

我们知道 ,mybatis框架存在pojo对象映射 , 直接将查询到的结果封装到对象中给我们返回, 但如果数据库的中的列和java中类属性名就是不一致,或者如果我们实际返回的对象需要去关联其他的对象(也就是说,其他类的对象作为我们这个类的成员变量),那么这时候使用resultType肯定是不行的

这里我们则需要去定义 resultMap来完成我们的需求

定义resultMap的过程就是描述如何从数据库结果集中去加载对象

resultMap多用于多表查询间的映射关系, 例如 :

我们以部门和员工为例 , 一个部门有多个员工 , 一个员工属于一个部门

建立部门表和员工表

CREATE TABLE dept(      -- 部门表
   id INT PRIMARY KEY AUTO_INCREMENT,
   NAME VARCHAR(10)
)

CREATE TABLE employee(  -- 员工表
   id INT PRIMARY KEY AUTO_INCREMENT,
   NAME VARCHAR(10),
   age INT,
   deptId INT
)

在java中创建 Dept(部门)类 和 Employee(员工)类

public class Employee {       //员工类
    private Integer id;
    private String name;
    private Integer age;
    // 一个员工关联一个部门
    private Dept dept;
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    public Dept getDept() {
        return dept;
    }
    public void setDept(Dept dept) {
        this.dept = dept;
    }
    @Override
    public String toString() {
        return "Employee{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", dept=" + dept +
                '}';
    }
}
public class Dept {
    private Integer id;
    private String name;
    // 一个部门有多个员工 ,使用List集合存储
    private List<Employee> list;
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public List<Employee> getList() {
        return list;
    }
    public void setList(List<Employee> list) {
        this.list = list;
    }
    @Override
    public String toString() {
        return "Dept{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", list=" + list +
                '}';
    }
}

首先我们查询员工 , 定义dao层接口 :

public interface EmployeeDao {
    // 查询所有员工
    List<Employee> selectAllEmployee();
}

由于我们在对象中关联了其他对象, 所以已经不是普通映射 ,这里我们定义 resultMap

    <resultMap id="employeeMap" type="Employee">
        <!--主键列-->
        <id column="id" property="id"/>
        <!--其他属性映射-->
        <result property="name" column="ename"/>
        <result property="age" column="age"/>
        <!--一对一关联-->
        <association property="dept" javaType="Dept">
            <!--需要映射的对象属性-->
            <result property="name" column="dname"/>
        </association>
    </resultMap>
    <select id="selectAllEmployee" resultMap="employeeMap">
        SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
                 LEFT JOIN dept d ON e.deptId = d.id
    </select>

resultMap 中的id 是唯一标识 , 相当于名字 , type类型是我们要返回的类型

<select>中使用resultMap , 传入刚定义的id即可

这样在java代码中我们就可以得到我们想要的映射格式

查询部门 :

public interface DeptDao {
    //查询部门
    List<Dept> selectDept();
}

定义与使用resultMap

<resultMap id="deptMap" type="Dept">
        <id column="id" property="id"/>
        <result column="dname" property="name"/>
        <!--collection为一对多 , 这里一个部门包含多个员工-->
        <collection property="list" javaType="List" ofType="Employee">
            <result property="name" column="ename"/>
        </collection>
    </resultMap>
    <select id="selectDept" resultMap="deptMap">
         SELECT d.id,d.name dname,e.name ename FROM dept d
              LEFT JOIN employee e ON d.id = e.deptId
    </select>

这里 JavaType我们选择list , 因为用list集合来存储多个员工信息, ofType是list集合中实际包含的对象名,这里是员工 Employee

通过resultMap 我们就可以得到自己想要的映射关系

到此这篇关于mybatis深入讲解resultMap的定义及用法的文章就介绍到这了,更多相关mybatis resultMap内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Mybatis实现ResultMap结果集

    ResultMap——解决属性名和字段名不一致的问题 数据库中的字段 新建一个项目,拷贝之前的,测试实体类字段不一致的情况 1.新建一个module——mybatis-03 2.新建db.properties配置文件 driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/mybatis?useSSL=false&useEncoding=false&characterEncoding=UTF-8&serverTime

  • Mybatis resultMap标签继承、复用、嵌套方式

    目录 resultMap标签继承.复用.嵌套 定义表与实体类 表 实体类 定义与表映射的resultMap 继承.复用.嵌套 使用resultmap需要注意的地方 resultMap标签继承.复用.嵌套 记录演示 Mybatis 中 resultMap 标签继承.复用(包括跨文件)以及多层嵌套的使用方法, 继承: 继承已存在的 resultMap 标签进行扩展 复用: 跨mapper文件引用现存的 resultMap 标签 嵌套: 多层嵌套的JavaBean与 resultMap 映射方法 定义

  • 解析mybatis-plus中的resultMap简单使用

    不一致,那么用来接收查询出来的result对应的数据将会是Null,如果不使用resultMap,那么一般为了避免pojo对象对应的属性为Null,会采用SQL语句中的别名,将查询出的数据库中的字段as pojo对象属性,而且,resultMap支持延迟加载 但是为了避免sql语句看着 臃肿,所以就使用了resultMap   简单使用  1.    选定你要进行的resultMap映射的model,如下是我要进行映射的model,model=======>Category.java[进行res

  • Java Mybatis使用resultMap时,属性赋值顺序错误的巨坑

    目录 Mybatis使用resultMap属性赋值顺序错误 ids是后加入的字段 resultMap中是这样写的 解决办法 Mybatis使用resultMap时需注意 Mybatis使用resultMap属性赋值顺序错误 今天发现个坑,新建的表使用生成工具生成的mapper文件和实体类后,发现少了个字段就又手动加了下,结果发现一个问题 ids是后加入的字段 @Data @Builder public class QueryRecordPo {        //若干其他属性....     p

  • Mybatis的resultMap返回map问题

    目录 resultMap返回map问题 简单封装resultMap返回对象为map resultMap返回map问题 <resultMap type="Map" id="bankMaintainMap"> <result column="bank_name" property="bankName"/> <result column="maintain_time_interval"

  • Mybatis开发要点-resultType和resultMap有什么区别详解

    目录 一.resultType 1.resultType介绍 2.映射规则 3.自动映射注意事项 4.代码演示 1.t_user_test.sql准备 2.实体类 3.Mapper接口类 4.Mapper xml 5.配置文件 6.启动测试类 7.执行结果 二.resultMap 1.resultMap  介绍 2.resultMap属性 3.使用场景 4.resultMap子元素属性 5.代码演示 1.mapper接口 2.Mapper.xml 3.启动测试 4.执行结果 三.结论 Mybat

  • MyBatis使用resultMap如何解决列名和属性名不一致

    目录 使用resultMap如何解决列名和属性名不一致 OrderMapper.xml配置 单元测试 实体属性名与表字段名不匹配问题 问题 解决方案一 解决方案二 使用resultMap如何解决列名和属性名不一致 resultType可以指定将查询结果映射为pojo,但需要pojo的属性名和sql查询的列名一致方可映射成功. 如果sql查询字段名和pojo的属性名不一致,可以通过resultMap将字段名和属性名作一个对应关系 ,resultMap实质上还需要将查询结果映射到pojo对象中. 需

  • mybatis深入讲解resultMap的定义及用法

    目录 我们知道 ,mybatis框架存在pojo对象映射 , 直接将查询到的结果封装到对象中给我们返回, 但如果数据库的中的列和java中类属性名就是不一致,或者如果我们实际返回的对象需要去关联其他的对象(也就是说,其他类的对象作为我们这个类的成员变量),那么这时候使用resultType肯定是不行的 这里我们则需要去定义 resultMap来完成我们的需求 定义resultMap的过程就是描述如何从数据库结果集中去加载对象 resultMap多用于多表查询间的映射关系, 例如 : 我们以部门和

  • Python数据结构与算法之链表定义与用法实例详解【单链表、循环链表】

    本文实例讲述了Python数据结构与算法之链表定义与用法.分享给大家供大家参考,具体如下: 本文将为大家讲解: (1)从链表节点的定义开始,以类的方式,面向对象的思想进行链表的设计 (2)链表类插入和删除等成员函数实现时需要考虑的边界条件, prepend(头部插入).pop(头部删除).append(尾部插入).pop_last(尾部删除) 2.1 插入: 空链表 链表长度为1 插入到末尾 2.2 删除 空链表 链表长度为1 删除末尾元素 (3)从单链表到单链表的一众变体: 带尾节点的单链表

  • MyBatis中的resultMap简要概述

    Mybatis简介 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录. Mybatis的功能架构分为三层(图片借用了百度百科): 1)       API接口层:提供给外部使用的接口API,开发人员通过这些本地API

  • Python排序算法之选择排序定义与用法示例

    本文实例讲述了Python排序算法之选择排序定义与用法.分享给大家供大家参考,具体如下: 选择排序 选择排序比较好理解,好像是在一堆大小不一的球中进行选择(以从小到大,先选最小球为例): 1. 选择一个基准球 2. 将基准球和余下的球进行一一比较,如果比基准球小,则进行交换 3. 第一轮过后获得最小的球 4. 在挑一个基准球,执行相同的动作得到次小的球 5. 继续执行4,直到排序好 时间复杂度:O(n^2).  需要进行的比较次数为第一轮 n-1,n-2....1, 总的比较次数为 n*(n-1

  • MyBatis动态Sql之if标签的用法详解

    最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用if标签生成动态的Sql,主要包含以下3个场景: 1.根据查询条件实现动态查询 2.根据参数值实现动态更新某些列 3.根据参数值实现动态插入某些列 1. 使用if标签实现动态查询 假设有这样1个需求:根据用户的输入条件来查询用户列表,如果输入了用户名,就根据用户名模糊查询,如果输入了邮箱,就根据邮箱精确查询,如果同时输入了

  • mybatis多层嵌套resultMap及返回自定义参数详解

    1.两层嵌套,一个list中加另外一个list data:[ {a:123,b:456,c:[{d:7,e:8}]} ] xml文件定义的sql select * from zhy z LEFT JOIN wl w on z.id = w.zid resultMap可以定义: <resultMap id="zhyResultMap" type="zhy的doman实体" extends="zhy自动生成的BaseResultMap">

  • Mybatis 复杂对象resultMap的使用

    目录 Mybatis 复杂对象resultMap 下面是resultMap的定义 普通属性省略说明 select相关配置 Model代码 resultMap处理复杂映射问题 Ⅰ 多对一查询:学生--老师 (1) 创建实体类POJO (2) 创建学生实体类对应的接口 (3) 编写学生接口对应的Mapper.xml (4)在核心配置类中引入Mapper Ⅱ 一对多查询:老师--学生 (1)实体类 (2) 接口 (3)接口对应的Mapper.xml (4)测试: Mybatis 复杂对象resultM

  • 详解MyBatis resultType与resultMap中的几种返回类型

    目录 一.返回集合 1.返回JavaBean集合 2.返回 Map 集合 二.返回 Map 1.一条记录 2.多条记录,需要指定 Map 的 Key 和 Value 的类型 三.返回 resultMap 自定义结果集封装 1.自定义 JavaBean 的封装 2.关联查询的封装,一对一,JavaBean 属性包含 JavaBean 3.关联查询的封装,一对多,JavaBean 属性包含 JavaBean 的集合 4.鉴别器discriminator 一.返回集合 1.返回JavaBean集合 p

  • MyBatis详细讲解DAO代理的使用

    目录 DAO代理实现数据库操作 1.去掉Dao接口实现类 2.getMapper获取代理对象 3.使用 Dao 代理对象方法执行 sql 语句 4.深入理解参数 parameterType 一个简单参数 使用@Param 使用对象 DAO代理实现数据库操作 1.去掉Dao接口实现类 2.getMapper获取代理对象 只需调用 SqlSession 的 getMapper()方法,即可获取指定接口的实现类对 象.该方法的参数为指定 Dao 接口类的 class 值. SqlSession ses

  • MyBatis 详细讲解动态 SQL的使用

    目录 MyBatis 框架动态 SQL 环境准备 动态 SQL 之 if 动态 SQL 之 where 动态 SQL 之 foreach 动态 SQL 之代码片段 MyBatis 框架动态 SQL 动态 SQL,通过 MyBatis 提供的各种标签对条件作出判断以实现动态拼接 SQL 语句.这里的条件判断使用的表达式为 OGNL 表达式.常用的动态 SQL 标签有<if>.<where>.<choose/>.<foreach>等. MyBatis 的动态 S

随机推荐