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

一对多映射(两种方式)
三张表关联查询。当然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集合属性表示父级部门中的子部门
    private List 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 getPdepts() {
        return pdepts;
    }

    public void setPdepts(List 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">
        
    select>

    
    <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 property="dept" javaType="com.example.data.Dept">
            <id column="id" property="id"/>
            <result column="dept_name" property="deptName"/>
        association>

        
        <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 selectOneToMany()throws Exception;

输出结果日志:

这里写图片描述

方式二:extends
与方式一不同点在于Mapper.xml:
上一篇一对一映射博客地址,下面实例会引用一个resultMap。

<select id="selectOneToMany"  resultMap="selectRstMapTwo">
        
    select>

    
    <resultMap type="com.example.data.User" id="selectRstMapTwo" extends="selectRstMap">
        
        <collection property="pdepts" ofType="com.example.data.Pdept">
            <id column="id" property="id"/>
            <result column="pdept_name" property="pdeptName"/>
        collection>
    resultMap>

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

你可能感兴趣的:(MyBatis)