成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Mybatis單表CRUD與多表關(guān)聯(lián)的無SQL通用方案_2: 無SQL實現(xiàn)關(guān)聯(lián)查詢的自動綁定

30e8336b8229 / 570人閱讀

摘要:對關(guān)聯(lián)另外的實體關(guān)聯(lián)查詢另外一張表的多個實體如部門實體對應(yīng)的對象中需要關(guān)聯(lián)多個子部門實體。對于關(guān)聯(lián)一個或多個實體的情況,一般通過的實現(xiàn)無的實現(xiàn)方案不寫,不通過的,要更優(yōu)雅的實現(xiàn)關(guān)聯(lián)的自動綁定,一個主流的方案就是類似的注解了。

上一篇無SQL實現(xiàn)單表CRUD中我們已經(jīng)通過Mybatis-plus插件的通用Mapper實現(xiàn)了單表的CRUD的無SQL化,已經(jīng)可以有效減少M(fèi)ybatis的代碼量。但實際開發(fā)場景下,多數(shù)業(yè)務(wù)需求實現(xiàn)要涉及關(guān)聯(lián)查詢,你可以通過自己寫SQL的方式去做,或者再深入思考一下有沒有更方便的實現(xiàn)方案呢?
涉及關(guān)聯(lián)的開發(fā)場景 1. 關(guān)聯(lián)查詢另外一張表的字段 1.1. id-name轉(zhuǎn)換:

如department表中有org_id字段,關(guān)聯(lián)organization表的id字段,前端顯示Department部門信息時需要顯示組織名稱organization.name。

class DepartmentVO{
    String orgName; //關(guān)聯(lián)organization表的name字段
}
1.2. 可配置的元數(shù)據(jù)/數(shù)據(jù)字典之類的value-label轉(zhuǎn)換

如department表中有狀態(tài)字段status,存儲值是"A","I"...,顯示時需要轉(zhuǎn)換為"正常","無效"...。

class DepartmentVO{
    String statusLabel; //關(guān)聯(lián)字典表轉(zhuǎn)換為顯示值
}
2. 關(guān)聯(lián)查詢另外一張表的單個實體

如部門實體Department(department表的Java映射對象)對應(yīng)的VO對象中需要關(guān)聯(lián)組織Organization實體(organization表的映射對象)。

class DepartmentVO {
    Organization organization; //1對1關(guān)聯(lián)另外的實體
}
3. 關(guān)聯(lián)查詢另外一張表的多個實體

如部門實體Department對應(yīng)的VO對象中需要關(guān)聯(lián)多個子部門Department實體。

class DepartmentVO{
    List children; //1對多關(guān)聯(lián)另外的實體
}
常規(guī)的實現(xiàn)方案

Mybatis-plus并未實現(xiàn)關(guān)聯(lián)查詢的解決方案:
對于字段關(guān)聯(lián),通常的解決方案是SQL關(guān)聯(lián)查詢,如:

SELECT d.*, o.name as orgName, m.item_label as statusLabel
FROM department d 
LEFT JOIN organization o ON d.org_id=o.id
LEFT JOIN metadata m ON u.status=m.item_value AND m.type="STATUS"

或者通過另外一種不太優(yōu)雅的方式:查詢整個表得到id-name的Map,然后通過Java代碼去綁定。

對于關(guān)聯(lián)一個或多個實體的情況,一般通過Mybatis的association實現(xiàn):


   
無SQL的實現(xiàn)方案

不寫SQL,不通過Mybatis的association,要更優(yōu)雅的實現(xiàn)關(guān)聯(lián)的自動綁定,一個主流的方案就是類似JPA的注解了。JPA的注解需要復(fù)雜的設(shè)置,我們可以只借鑒其思想,將注解盡可能的簡化。

首先,需要明確關(guān)聯(lián)到哪個表(實體),另外不管是哪種關(guān)聯(lián)都必須要有關(guān)聯(lián)條件condition,然后是字段關(guān)聯(lián)呢我們需要指定字段名field。

那么我們可以將注解定義簡化如下:

public class DepartmentVO {
    ...
    // 關(guān)聯(lián)Entity中的某字段
    @BindField(entity=Organization.class, field="name", condition="this.org_id=id")
    private String orgName;

    // 關(guān)聯(lián)Entity
    @BindEntity(entity=Organization.class, condition="this.org_id=id")
    private Organization organization;

    // 關(guān)聯(lián)多個Entity
    @BindEntityList(entity=Department.class, condition="this.id=parent_id")
    private List children;
}

簡化的使用意味著要有完善的實現(xiàn)邏輯,后續(xù)的章節(jié)我們將具體講解這些關(guān)聯(lián)綁定注解的實現(xiàn)方案。

Diboot - 簡單高效的輕代碼開發(fā)框架

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/74747.html

相關(guān)文章

  • MyBatis-Plus初步

    摘要:是最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)之一,在應(yīng)用方面,是最好的,關(guān)系數(shù)據(jù)庫管理系統(tǒng)應(yīng)用軟件。是一種關(guān)系數(shù)據(jù)庫管理系統(tǒng),關(guān)系數(shù)據(jù)庫將數(shù)據(jù)保存在不同的表中,而不是將所有數(shù)據(jù)放在一個大倉庫內(nèi),這樣就增加了速度并提高了靈活性。 本章主要是對MyBatis-Plus的初步介紹,包括一些背景知識、環(huán)境搭建、初步使用等知識和例子。對于背景知識,主要包含對MyBatis-Plus的特性介紹、為什么使用MyB...

    娣辯孩 評論0 收藏0
  • Mybatis【配置文件】就是這么簡單

    摘要:場合常見一些明細(xì)記錄的展示,將關(guān)聯(lián)查詢信息全部展示在頁面時,此時可直接使用將每一條記錄映射到中,在前端頁面遍歷中是即可。如果查詢單表就可以滿足需求,一開始先查詢單表,當(dāng)需要關(guān)聯(lián)信息時,再關(guān)聯(lián)查詢,當(dāng)需要關(guān)聯(lián)信息再查詢這個叫延遲加載。 配置文件和映射文件還有挺多的屬性我還沒有講的,現(xiàn)在就把它們一一補(bǔ)全 映射文件 在mapper.xml文件中配置很多的sql語句,執(zhí)行每個sql語句時,封裝...

    freewolf 評論0 收藏0
  • MyBatis理解與掌握(關(guān)聯(lián)查詢

    摘要:訂單信息與訂單明細(xì)為一對多關(guān)系。例如先從單表查詢,需要時再從關(guān)聯(lián)表去關(guān)聯(lián)查詢,大大提高數(shù)據(jù)庫性能,因為查詢單表要比關(guān)聯(lián)查詢多張表速度要快。作用將關(guān)聯(lián)查詢信息映射到一個對象中。 MyBatis理解與掌握(關(guān)聯(lián)查詢) @(MyBatis)[Java, 框架, MyBatis] 一對一查詢 案例:查詢所有訂單信息,關(guān)聯(lián)查詢下單用戶信息 showImg(https://segmentfault...

    MiracleWong 評論0 收藏0
  • MyBatis緩存介紹

    摘要:緩存介紹正如大多數(shù)持久層框架一樣,同樣提供了一級緩存和二級緩存的支持一級緩存基于的本地緩存,其存儲作用域為,當(dāng)或之后,該中的所有就將清空。一級緩存實現(xiàn)對的操作內(nèi)部都是通過來執(zhí)行的。 MyBatis緩存介紹   正如大多數(shù)持久層框架一樣,MyBatis 同樣提供了一級緩存和二級緩存的支持   一級緩存: 基于PerpetualCache 的 HashMap本地緩存,其存儲作用域為 Se...

    mingde 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<