国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

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

30e8336b8229 / 559人閱讀

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

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

如department表中有org_id字段,關(guān)聯(lián)organization表的id字段,前端顯示Department部門信息時(shí)需要顯示組織名稱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,存儲(chǔ)值是"A","I"...,顯示時(shí)需要轉(zhuǎn)換為"正常","無(wú)效"...。

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

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

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

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

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

Mybatis-plus并未實(shí)現(xiàn)關(guān)聯(lián)查詢的解決方案:
對(duì)于字段關(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"

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

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


   
無(wú)SQL的實(shí)現(xiàn)方案

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

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

那么我們可以將注解定義簡(jiǎn)化如下:

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)多個(gè)Entity
    @BindEntityList(entity=Department.class, condition="this.id=parent_id")
    private List children;
}

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

Diboot - 簡(jiǎn)單高效的輕代碼開(kāi)發(fā)框架

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/74747.html

相關(guān)文章

  • MyBatis-Plus初步

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

    娣辯孩 評(píng)論0 收藏0
  • Mybatis【配置文件】就是這么簡(jiǎn)單

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

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

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

    MiracleWong 評(píng)論0 收藏0
  • MyBatis緩存介紹

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

    mingde 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<