欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

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

时间:2023-08-06
mybatis内部类的映射及注意事项

前言一、一般情况一对多关系映射二、内部类的一对多关系映射

1.建立内部类和关系2.mapper中resultMap映射注意点


前言

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


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


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

首先,我们要建立部门和员工表对应的实体类;并在部门中建立员工的一对多关系的list;

@Datapublic class DeptVo { private Long deptId; private String deptName; private List employeeVoList;}

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

然后,在mapper中映射即可;

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

最后通过接口返回;

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

这样来得到我们想要的结果;

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

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

1.建立内部类和关系

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

@Datapublic class DeptVo { private Long deptId; private String deptName; private List 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修饰;

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

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。