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修饰;
–本文主要作为个人学习记录,方便后续查阅修正;