必威体育Betway必威体育官网
当前位置:首页 > IT技术

Mybatis之高级映射【一对多映射】

时间:2019-10-06 07:13:20来源:IT技术作者:seo实验室小编阅读:77次「手机版」
 

映射

一对多映射(两种方式)

三张表关联查询。当然resultType也能实现,需要将所查询的信息定义到一个pojo(详情见一对一映射中的resultType),这里讲的是resultMap。

需求:查询人员、部门信息并关联查询其父级部门信息。

随意定义数据库的三张表:

人员表:

这里写图片描述

部门表:

这里写图片描述

父级部门表:

这里写图片描述

方式一:association (一对一映射)+collection(一对多映射)

a.建立人员表的pojo:

package com.example.data;

import java.util.List;

public class User {
    private String id;
    private String deptId;
    private String name;
    private String sex;
    private String age;
    private String remark;

    /**
     * User表中有一个dept_id字段,要在User类中定义一个dept属性,
     * 用于维护dept和user之间的一对一关系
     */
    private Dept dept;

    //使用一个List<Pdept>集合属性表示父级部门中的子部门
    private List<Pdept> pdepts;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getDeptId() {
        return deptId;
    }

    public void setDeptId(String deptId) {
        this.deptId = deptId;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public String getAge() {
        return age;
    }

    public void setAge(String age) {
        this.age = age;
    }

    public String getRemark() {
        return remark;
    }

    public void setRemark(String remark) {
        this.remark = remark;
    }

    public Dept getDept() {
        return dept;
    }

    public void setDept(Dept dept) {
        this.dept = dept;
    }

    public List<Pdept> getPdepts() {
        return pdepts;
    }

    public void setPdepts(List<Pdept> pdepts) {
        this.pdepts = pdepts;
    }

    @Override
    public String toString() {
        return "User{" +
                "id='" + id + '\'' +
                ", deptId='" + deptId + '\'' +
                ", name='" + name + '\'' +
                ", sex='" + sex + '\'' +
                ", age='" + age + '\'' +
                ", remark='" + remark + '\'' +
                ", dept=" + dept +
                ", pdepts=" + pdepts +
                '}';
    }
}

b.建立部门表的pojo:

package com.example.data;

public class Dept {
    private String id;
    private String deptName;
    private String parentId;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getDeptName() {
        return deptName;
    }

    public void setDeptName(String deptName) {
        this.deptName = deptName;
    }

    public String getParentId() {
        return parentId;
    }

    public void setParentId(String parentId) {
        this.parentId = parentId;
    }

    @Override
    public String toString() {
        return "Dept{" +
                "id='" + id + '\'' +
                ", deptName='" + deptName + '\'' +
                ", parentId='" + parentId + '\'' +
                '}';
    }
}

b.建立父级部门表的pojo:

package com.example.data;

public class Pdept {
    private String id;
    private String pdeptName;

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getPdeptName() {
        return pdeptName;
    }

    public void setPdeptName(String pdeptName) {
        this.pdeptName = pdeptName;
    }

    @Override
    public String toString() {
        return "Pdept{" +
                "id='" + id + '\'' +
                ", pdeptName='" + pdeptName + '\'' +
                '}';
    }
}

b.编写MAPPer.xml:

<select id="selectOneToMany"  resultMap="selectRstMapTwo">
        <![CDATA[
            select * from bank_user,bank_dept,bank_pdept where bank_user.dept_id=bank_dept.id 
            and bank_dept.parent_id=bank_pdept.id
        ]]>
    </select>

    <!--定义resultmap
        column:数据库中对应的列名(名字必须完全一样)
        property:实体类pojo中的属性名(名字必须完全一样)-->
    <resultMap type="com.example.data.User" id="selectRstMapTwo">
        <id column="id" property="id"/>
        <result column="name" property="name"/>
        <result column="age" property="age"/>
        <result column="sex" property="sex"/>
        <!--association:一对一关联映射-->
        <association property="dept" javaType="com.example.data.Dept">
            <id column="id" property="id"/>
            <result column="dept_name" property="deptName"/>
        </association>

        <!-- collection:一对多关联映射 
             property表示集合类型属性名称,也就是User实体类中定义的部门List名字
             ofType表示集合中的对象的类型-->
        <collection property="pdepts" ofType="com.example.data.Pdept">
            <id column="id" property="id"/>
            <result column="pdept_name" property="pdeptName"/>
        </collection>
    </resultMap>

c.编写Mapper.java:

    //一对多查询:查询人员、部门信息并关联查询其父级部门信息
    public List<User> selectOneToMany()throws Exception;

输出结果日志:

这里写图片描述

方式二:extends

与方式一不同点在于Mapper.xml:

上一篇一对一映射博客地址,下面实例会引用一个resultMap。

<select id="selectOneToMany"  resultMap="selectRstMapTwo">
        <![CDATA[
            select * from bank_user,bank_dept,bank_pdept where bank_user.dept_id=bank_dept.id 
            and bank_dept.parent_id=bank_pdept.id
        ]]>
    </select>

    <!--定义resultmap
        column:数据库中对应的列名(名字必须完全一样)
        property:实体类pojo中的属性名(名字必须完全一样)
        extends:继承一个resultMap,把其中的所有配置都继承(这里继承的是上一篇一对一映射的resultMap)
        使用extends,只编写collection元素即可。
    -->
    <resultMap type="com.example.data.User" id="selectRstMapTwo" extends="selectRstMap">
        <!-- collection:一对多关联映射 
             property表示集合类型属性名称,也就是User实体类中定义的部门List名字
             ofType表示集合中的对象的类型-->
        <collection property="pdepts" ofType="com.example.data.Pdept">
            <id column="id" property="id"/>
            <result column="pdept_name" property="pdeptName"/>
        </collection>
    </resultMap>

高级映射:【一对一映射】 【多对多映射】

相关阅读

如何成为一个高级程序员,然后呢....

如果你本身是个技术大牛,就可以忽略这篇内容;如果你觉得可能有点意思,可以读一读。好吧,进入正题....第一,亲自写一个小游戏,调试跟踪代

spring data jpa-由mybatis切换

最近重构以前写的服务,最大的一个变动是将mybatis切换为spring data jpa,切换的原因很简单,有两点:第一、它是spring的子项目能够和sp

hbase-高级API-协处理器(Observer)

协处理器 过滤器减少服务器端通过网络返回到客户端 的数据量 协处理器(coprocessor):HBase把部分计算移到数据的存放端 协处理器简介

实现宿主机到虚拟机的端口映射(端口转发)

测试环境: 宿主机:Windows Server 2003 R2 Enterprise X64 Edition 虚拟机:VM10.0.2 ,装的CentOS7.4 需求背景: 宿主机系统更换麻

MikroTik - WinBox设置端口映射

【1】背景需求 让外网直接放我我本机web项目。百度了解决方法如下:端口映射,DDNS(花生壳)。 也就是说让外网访问公司ip,然后直接映

分享到:

栏目导航

推荐阅读

热门阅读