亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

mybatis映射內(nèi)部類的使用及注意事項說明

 更新時間:2023年12月01日 16:33:42   作者:Quader  
這篇文章主要介紹了mybatis映射內(nèi)部類的使用及注意事項說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

前言

項目中經(jīng)常會遇到一對多的關(guān)系,我們在java中也經(jīng)常要做一對多關(guān)系的mybatis的映射處理;

當(dāng)然也不排除我們會遇到需要映射到內(nèi)部類的情況;

那么如果需要用內(nèi)部類映射該怎么使用,又有哪些注意事項呢?

示例:

現(xiàn)有部門和員工兩張表;每個部門都有一個或多個員工;現(xiàn)需要返回每個部門和其部門下的所有員工;

一般情況一對多關(guān)系映射

首先,我們要建立部門和員工表對應(yīng)的實體類;并在部門中建立員工的一對多關(guān)系的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();
    }

這樣來得到我們想要的結(jié)果;

內(nèi)部類的一對多關(guān)系映射

那么如果對應(yīng)的實體類要用內(nèi)部類的話,我們又該怎樣去處理呢;

1.建立內(nèi)部類和關(guān)系

mybatis要想用內(nèi)部類作為返回結(jié)果,要求內(nèi)部類要有無參構(gòu)造,且必須是靜態(tài)內(nè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映射

內(nèi)部類的映射表示為所在類$內(nèi)部類,代碼如下(示例):

其余部分保持一致即可;

注意點

01:resultType后面的內(nèi)部類用$符號連接;

02:內(nèi)部類必須有無參構(gòu)造函數(shù);

03:內(nèi)部類必須為靜態(tài)類有static修飾;

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • Java數(shù)據(jù)結(jié)構(gòu)之散列表(動力節(jié)點Java學(xué)院整理)

    Java數(shù)據(jù)結(jié)構(gòu)之散列表(動力節(jié)點Java學(xué)院整理)

    散列表(Hash table,也叫哈希表),是根據(jù)關(guān)鍵字(key value)而直接進行訪問的數(shù)據(jù)結(jié)構(gòu)。這篇文章給大家介紹了java數(shù)據(jù)結(jié)構(gòu)之散列表,包括基本概念和散列函數(shù)相關(guān)知識,需要的的朋友參考下吧
    2017-04-04
  • 使用springboot時,解決@Scheduled定時器遇到的問題

    使用springboot時,解決@Scheduled定時器遇到的問題

    這篇文章主要介紹了使用springboot時,解決@Scheduled定時器遇到的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java通過SMS短信平臺實現(xiàn)發(fā)短信功能 含多語言

    Java通過SMS短信平臺實現(xiàn)發(fā)短信功能 含多語言

    這篇文章主要為大家詳細(xì)介紹了Java通過SMS短信平臺實現(xiàn)發(fā)短信功能的相關(guān)資料,感興趣的小伙伴們可以參考一下
    2016-07-07
  • spring boot aop 記錄方法執(zhí)行時間代碼示例

    spring boot aop 記錄方法執(zhí)行時間代碼示例

    這篇文章主要介紹了spring boot aop 記錄方法執(zhí)行時間代碼示例,分享了相關(guān)代碼,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Go Java算法之簡化路徑實例詳解

    Go Java算法之簡化路徑實例詳解

    這篇文章主要為大家介紹了Go Java算法之簡化路徑實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • Java Socket上的Read操作阻塞問題詳解

    Java Socket上的Read操作阻塞問題詳解

    這篇文章主要介紹了Java Socket上的Read操作阻塞問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • 關(guān)于Maven parent.relativePath說明

    關(guān)于Maven parent.relativePath說明

    Maven中的relativePath用于指定父項目pom.xml的相對路徑,默認(rèn)值為../pom.xml,這個配置幫助Maven在構(gòu)建時定位父模塊的位置,確保模塊間的依賴關(guān)系正確,relativePath可以指向本地或遠(yuǎn)程倉庫中的父項目,如果不需要尋找父項目,可以將其設(shè)置為空
    2024-09-09
  • spring中定時任務(wù)taskScheduler的詳細(xì)介紹

    spring中定時任務(wù)taskScheduler的詳細(xì)介紹

    這篇文章主要介紹了spring中定時任務(wù)taskScheduler的相關(guān)資料,文中通過示例代碼介紹的很詳細(xì),相信對大家具有一定的參考價值,有需要的朋友們下面來一起看看吧。
    2017-02-02
  • SpringBoot整合Apollo配置中心快速使用詳解

    SpringBoot整合Apollo配置中心快速使用詳解

    本文主要介紹了SpringBoot整合Apollo配置中心快速使用詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Java實現(xiàn)平鋪列表(List)互轉(zhuǎn)樹形(Tree)結(jié)構(gòu)

    Java實現(xiàn)平鋪列表(List)互轉(zhuǎn)樹形(Tree)結(jié)構(gòu)

    本文主要介紹了Java實現(xiàn)平鋪列表(List)互轉(zhuǎn)樹形(Tree)結(jié)構(gòu),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08

最新評論