广告
返回顶部
首页 > 资讯 > 后端开发 > Python >mybatis深入讲解resultMap的定义及用法
  • 775
分享到

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

2024-04-02 19:04:59 775人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

        我们知道 ,mybatis框架存在pojo对象映射 , 直接将查询到的结果封装到对象中给我们返回, 但如果数据库的中的列和ja

        我们知道 ,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内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: mybatis深入讲解resultMap的定义及用法

本文链接: https://www.lsjlt.com/news/147519.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mybatis深入讲解resultMap的定义及用法
            我们知道 ,mybatis框架存在pojo对象映射 , 直接将查询到的结果封装到对象中给我们返回, 但如果数据库的中的列和ja...
    99+
    2022-11-13
  • C语言深入讲解宏的定义与使用方法
    目录一、C语言中的宏定义二、宏定义表达式三、宏表达式与函数的对比四、有趣的问题五、强大的内置宏六、小结一、C语言中的宏定义 #define是预处理器处理的单元实体之一#define ...
    99+
    2022-11-13
  • C语言由浅入深讲解线程的定义
    目录线程的概念线程的创建线程的终止线程标识的比较线程的取消线程等待线程分离线程的概念 可以简单理解为一个正在独立运行的函数 注: 1.posix线程是一套标准吗,而不是实现 2.线程...
    99+
    2022-11-13
  • golang struct json tag的使用以及深入讲解
    目录一、sturct json tag的使用1.tag格式说明2.具体使用格式说明二、源码角度的设计处理过程1.typeFields2.encode三、总结一、sturct json...
    99+
    2022-11-13
  • C++深入讲解初始化列表的用法
    目录一、小问题二、类成员的初始化三、类中的 const 成员四、初始化与赋值的不同五、小结一、小问题 下面的类定义是否合法 如果合法,ci 的值是什么,存储在哪里 下面编写代码一探...
    99+
    2022-11-13
  • vue3组件中v-model的使用以及深入讲解
    目录v-model input中使用双向绑定数据 组件中的v-model 其他写法 总结v-model input中使用双向绑定数据 v-model在vue中我们经常用它与inpu...
    99+
    2022-11-12
  • Java深入讲解Object类常用方法的使用
    目录1.Object类的常用方法2.equals()方法3.toString方法4.getClass方法5.对象运算符instanceof实例Java代码java继承 1.Objec...
    99+
    2022-11-13
  • vue中4个自定义指令讲解及实例用法
    四个实用的vue自定义指令 1、v-drag 需求:鼠标拖动元素 思路: 元素偏移量 = 鼠标滑动后的坐标 - 鼠标初始点击元素时的坐标 + 初始点击时元素距离可视区域的top、le...
    99+
    2022-11-12
  • 深入理解Java中包的定义与使用
    目录包是什么?包的作用导入包中的类自定义包包的访问权限控制包是什么? 在开发过程中,会定义很多类,随着类越写越多,难免会出现类重名而发生覆盖的情况,为了在使用它们的时候不让编译器混淆...
    99+
    2022-11-12
  • 深入了解Android中GestureDetector的定义与使用
    目录简介赋予widget可以点击的功能会动的组件可删除的组件总结简介 之前我们介绍了GestureDetector的定义和其提供的一些基本的方法,GestureDetector的好处...
    99+
    2023-01-31
    Android GestureDetector使用 Android GestureDetector
  • 深入解析SQL的定义和使用范围
    SQL的定义及应用领域详解摘要:本文旨在介绍 SQL(Structured Query Language)的定义及其在不同应用领域中的具体应用。首先,我们将简要介绍 SQL 的定义和历史背景。接着,我们将深入探讨 SQL 在数据管理、数据分...
    99+
    2023-12-28
    SQL 定义 应用 领域
  • Java由浅入深全面讲解方法的使用
    目录一、方法的概念及其使用1.1、什么是方法1.2、方法的定义1.3、方法调用的执行过程1.4、实参和形参的关系(重要)二、方法的重载2.1、为什么需要方法重载2.2、方法重载的定义...
    99+
    2022-11-13
  • 深入讲解数据库中Decimal类型的使用以及实现方法
    目录1 背景2 Decimal类型的使用2.1 描述Decimal2.2 建表时定义Decimal2.3 写入decimal数据2.4 取出deimcal进行计算3 Decimal类...
    99+
    2022-11-13
  • 深入了解SparkSQL的运用及方法
    目录一:SparkSQL1.SparkSQL简介2.SparkSQL运行原理3.SparkSQL特点二、SparkSQL运用一:SparkSQL 1.SparkSQL简介 Spark...
    99+
    2022-11-13
  • C++深入讲解引用的特点及与指针的区别
    目录一.引入二.C++中较为麻烦的运算符三.引用的定义四.引用的特点五.对比指针与引用六.引用与指针的区别1.语法层面的区别2.汇编层面的区别七.引用的其他使用常引用数组引用指针引用...
    99+
    2022-11-13
  • 深入了解C++封闭类的定义与使用
    目录封闭类轮胎类引擎类汽车类总代码封闭类 今天,我学习的是C++对象的一种操作.就是成员对象和封闭类. 那么封闭类是什么呢和普通类用什么不同吗 封闭类就是有成员对象的类,那么成员对象...
    99+
    2022-11-13
    C++封闭类使用 C++封闭类
  • C++深入浅出讲解隐藏this指针的用法
    目录1.this指针的引出2.this指针的特性3.练习一下本篇文章我们将一起讨论在有趣的知识点--隐藏的this指针。本篇我们要使用到之前我们所学习到的C++类与对象,如果有各位小...
    99+
    2022-11-13
  • 深入浅出讲解Spring框架中AOP及动态代理的应用
    目录一. Spring AOP1. 传统问题:2. 问题的解决策略:3. AOP优点: 二. 动态代理1. JDK动态代理2. CGLIB代理一. Spring AOP &...
    99+
    2022-11-13
  • 实例讲解Android中的View类以及自定义View控件的方法
    View的简单理解和实例 1.View的基本概念 在Activity显示的控件 都叫做View(View类 是所有的控件类的父类  比如 文本 按钮) 2.在Acti...
    99+
    2022-06-06
    view 方法 自定义view Android
  • 深入探讨PHP私有静态方法的定义和使用
    PHP是一种非常流行的编程语言,经常用于Web应用程序开发。在PHP中,可以使用静态方法来执行一些与类相关的任务,而私有静态方法则是PHP面向对象编程中的一种特殊类型。在本文中,我们将深入探讨PHP私有静态方法的用途、如何定义和使用,以及它...
    99+
    2023-05-14
    私有静态方法 php
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作