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修饰;
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
java客户端Jedis操作Redis Sentinel 连接池的实现方法
下面小编就为大家带来一篇java客户端Jedis操作Redis Sentinel 连接池的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-03-03springboot整合webservice使用简单案例总结
WebService是一个SOA(面向服务的编程)的架构,它是不依赖于语言,平台等,可以实现不同的语言间的相互调用,下面这篇文章主要给大家介绍了关于springboot整合webservice使用的相关资料,需要的朋友可以参考下2024-07-07Java I/O (Input/Output)文件字节流举例详解
Java的输入输出流(IO)是用于与外部设备(如文件、网络连接等)进行数据交互的机制,下面这篇文章主要给大家介绍了关于Java I/O (Input/Output)文件字节流的相关资料,需要的朋友可以参考下2024-08-08
最新评论