mybatis映射内部类的使用及注意事项


前言

项目中经常会遇到一对多的关系,我们在java中也经常要做一对多关系的mybatis的映射处理;当然也不排除我们会遇到需要映射到内部类的情况;那么如果需要用内部类映射该怎么使用,又有哪些注意事项呢?


示例:现有部门和员工两张表;每个部门都有一个或多个员工;现需要返回每个部门和其部门下的所有员工;

在这里插入图片描述
在这里插入图片描述

一、一般情况一对多关系映射

首先,我们要建立部门和员工表对应的实体类;并在部门中建立员工的一对多关系的list;
@Data
public class DeptVo {
    /**部门id*/
    private Long deptId;
    /**部门名称*/
    private String deptName;
    /**部门员工(一对多)*/
    private List<EmployeeVo> employeeVoList;
}
@Data
public class EmployeeVo {
    private String employeeId;
    private String employeeName;
    private String employeeIntro;
    private Integer employeeAge;
}

然后,在mapper中映射即可;

<resultMap id="deptMap" type="com.cxk.demo1.pojo.DeptVo">
        <result column="deptId" property="deptId" />
        <result column="deptName" property="deptName" />
        <collection property="employeeVoList" ofType="com.cxk.demo1.pojo.EmployeeVo">
            <result column="employeeId" property="employeeId" />
            <result column="employeeName" property="employeeName" />
            <result column="employeeIntro" property="employeeIntro" />
            <result column="employeeAge" property="employeeAge" />
        </collection>
    </resultMap>

    <select id="listDeptWithEmployee" resultMap="deptMap">
        select
            d.id        deptId,
            d.name      deptName,
            e.id        employeeId,
            e.name      employeeName,
            e.intro     employeeIntro,
            e.age       employeeAge
        from t_dept d
        LEFT JOIN t_employee e on d.id = e.dept_id
        order BY d.name
    </select>

最后通过接口返回;

	@Override
    public List<DeptVo> getDept() {
        return deptMapper.listDeptWithEmployee();
    }

这样来得到我们想要的结果;
在这里插入图片描述

二、内部类的一对多关系映射

那么如果对应的实体类要用内部类的话,我们又该怎样去处理呢;

1.建立内部类和关系

mybatis要想用内部类作为返回结果,要求内部类要有无参构造,且必须是静态内部类;
代码如下(示例):

@Data
public class DeptVo {

    /**部门id*/
    private Long deptId;
    /**部门名称*/
    private String deptName;
    /**部门员工(一对多)*/
    private List<EmployeeVo> employeeVoList;

    @Data
    static class EmployeeVo{
        private String employeeId;
        private String employeeName;
        private String employeeIntro;
        private Integer employeeAge;
    }
}

2.mapper中resultMap映射

内部类的映射表示为所在类$内部类,代码如下(示例):
在这里插入图片描述
其余部分保持一致即可;

注意点

01:resultType后面的内部类用$符号连接;
02:内部类必须有无参构造函数;
03:内部类必须为静态类有static修饰;

–本文主要作为个人学习记录,方便后续查阅修正;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值