摘要:對關(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常規(guī)的實現(xiàn)方案children; //1對多關(guān)聯(liá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 Listchildren; }
簡化的使用意味著要有完善的實現(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)系型數(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...
摘要:場合常見一些明細(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語句時,封裝...
摘要:訂單信息與訂單明細(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...
摘要:緩存介紹正如大多數(shù)持久層框架一樣,同樣提供了一級緩存和二級緩存的支持一級緩存基于的本地緩存,其存儲作用域為,當(dāng)或之后,該中的所有就將清空。一級緩存實現(xiàn)對的操作內(nèi)部都是通過來執(zhí)行的。 MyBatis緩存介紹 正如大多數(shù)持久層框架一樣,MyBatis 同樣提供了一級緩存和二級緩存的支持 一級緩存: 基于PerpetualCache 的 HashMap本地緩存,其存儲作用域為 Se...
閱讀 2999·2023-04-25 21:23
閱讀 3042·2021-09-22 15:24
閱讀 870·2019-08-30 12:55
閱讀 2104·2019-08-29 18:42
閱讀 2615·2019-08-29 16:27
閱讀 955·2019-08-26 17:40
閱讀 2189·2019-08-26 13:29
閱讀 2614·2019-08-26 11:45