摘要:對(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常規(guī)的實(shí)現(xiàn)方案children; //1對(duì)多關(guān)聯(lián)另外的實(shí)體 }
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 Listchildren; }
簡(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)系型數(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...
摘要:場(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í),封裝...
摘要:訂單信息與訂單明細(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...
摘要:緩存介紹正如大多數(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...
閱讀 2989·2023-04-25 21:23
閱讀 3022·2021-09-22 15:24
閱讀 862·2019-08-30 12:55
閱讀 2095·2019-08-29 18:42
閱讀 2607·2019-08-29 16:27
閱讀 944·2019-08-26 17:40
閱讀 2173·2019-08-26 13:29
閱讀 2604·2019-08-26 11:45