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要想用內部類作為返回結果,要求內部類要有無參構造,且必須是靜態(tài)內部類;
代碼如下(示例):
@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:內部類必須為靜態(tài)類有static修飾;
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Java數據結構之散列表(動力節(jié)點Java學院整理)
散列表(Hash table,也叫哈希表),是根據關鍵字(key value)而直接進行訪問的數據結構。這篇文章給大家介紹了java數據結構之散列表,包括基本概念和散列函數相關知識,需要的的朋友參考下吧2017-04-04
使用springboot時,解決@Scheduled定時器遇到的問題
這篇文章主要介紹了使用springboot時,解決@Scheduled定時器遇到的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11
spring boot aop 記錄方法執(zhí)行時間代碼示例
這篇文章主要介紹了spring boot aop 記錄方法執(zhí)行時間代碼示例,分享了相關代碼,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-02-02

