一对多映射(两种方式)
三张表关联查询。当然resultType也能实现,需要将所查询的信息定义到一个pojo(详情见一对一映射中的resultType),这里讲的是resultMap。
需求:查询人员、部门信息并关联查询其父级部门信息。
随意定义数据库的三张表:

人员表:
Mybatis之高级映射【一对多映射】_一对多
部门表:
Mybatis之高级映射【一对多映射】_一对多_02
父级部门表:
Mybatis之高级映射【一对多映射】_关联查询_03

方式一: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;

输出结果日志:

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

方式二: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>

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