微服務之間調用外鍵“翻譯”的方法概述

寫在前面的話:減少strean流操作,減少多層嵌套for循環。使用普通for循環和map的方式進行轉換,

第一步查詢數據

List<Student> findList = studentDao.findList(findMap);

第二步準備遍歷和賦值

if(CollectionUtil.isNotEmpty(findList)){// 第一次遍歷,取出所有待翻譯的字段,避免重復使用steam流取值Set<String> courseSet = new HashSet<>(16);Set<String> schooldSet = new HashSet<>(16);Set<String> nativePlaceSet = new HashSet<>(16);for (Student student : findList) {// 課程idString courseId = student.getSourceId();if(StringUtil.isNotEmpty(courseId)){courseSet.add(courseId);}// 學校idString schooldId = student.getSchoold();if(StringUtil.isNotEmpty(schooldId)){schooldSet.add(schooldId);}// 籍貫idString nativePlaceId = student.getNativePlace();if(StringUtil.isNotEmpty(nativePlaceId)){nativePlaceSet.add(nativePlaceId);}}// 查詢課程信息、學校信息、籍貫信息,并轉換成mapMap<String,Object> findMap = new HashMap<>(16);findMap.put("courseSet",courseSet);findMap.put("schooldSet",schooldSet);findMap.put("nativePlaceSet",nativePlaceSet);List<Course> courseList = courseDao.findList(findMap);List<Schoold> schooldList = schooldDao.findList(findMap);List<NativePlace> nativePlaceList = nativePlaceDao.findList(findMap);// 轉換成mapMap<String,Course> courseMap = CollectionUtil.isEmpty(courseList) ? new HashMap<>(0) :courseList.stream().collect(Collectors.toMap(Course::getId, course -> course));Map<String,Schoold> schooldMap = CollectionUtil.isEmpty(schooldList) ? new HashMap<>(0) :courseList.stream().collect(Collectors.toMap(Schoold::getId, schoold -> schoold));Map<String,NativePlace> nativePlaceMap = CollectionUtil.isEmpty(nativePlaceList) ? new HashMap<>(0) :courseList.stream().collect(Collectors.toMap(NativePlace::getId, nativePlace -> nativePlace));// 第二次遍歷,填充翻譯后的值for (Student student : findList) {// 課程id-->課程名稱String courseId = student.getSourceId();if(StringUtil.isNotEmpty(courseId)){student.setSourceName(courseMap.get(courseId).getName());}// 學校id-->學校名稱String schooldId = student.getSchoold();if(StringUtil.isNotEmpty(schooldId)){student.setSchooldName(schooldMap.get(schooldId).getName());}// 籍貫id-->籍貫名稱String nativePlaceId = student.getNativePlace();if(StringUtil.isNotEmpty(nativePlaceId)){student.setNativePlaceName(nativePlaceMap.get(nativePlaceId).getName());}}}

結語:僅遍歷2次,減少了stream流取值。用轉map的方式減少了多層for循環。

使用阿里的“通益千問”,指定java17將代碼優化如下:

List<Student> findList = studentDao.findList(findMap);
if (CollectionUtil.isNotEmpty(findList)) {// 單次遍歷收集所有ID(性能優化核心)Set<String> courseSet = new HashSet<>(16);Set<String> schoolSet = new HashSet<>(16);Set<String> nativePlaceSet = new HashSet<>(16);for (Student student : findList) {addIfNotEmpty(courseSet, student.getSourceId());addIfNotEmpty(schoolSet, student.getSchoold());addIfNotEmpty(nativePlaceSet, student.getNativePlace());}// 構建查詢參數Map<String, Object> queryMap = new HashMap<>(16);queryMap.put("courseSet", courseSet);queryMap.put("schoolSet", schoolSet); // 修正拼寫錯誤queryMap.put("nativePlaceSet", nativePlaceSet);// 查詢關聯數據List<Course> courseList = courseDao.findList(queryMap);List<School> schoolList = schoolDao.findList(queryMap); // 修正類名List<NativePlace> nativePlaceList = nativePlaceDao.findList(queryMap);// 轉換為Map(使用輔助方法簡化)Map<String, Course> courseMap = toMap(courseList, Course::getId);Map<String, School> schoolMap = toMap(schoolList, School::getId);Map<String, NativePlace> nativePlaceMap = toMap(nativePlaceList, NativePlace::getId);// 填充學生信息(使用Optional處理空值)for (Student student : findList) {// 課程ID → 課程名稱String courseId = student.getSourceId();student.setSourceName(courseMap.getOrDefault(courseId, new Course()).getName());// 學校ID → 學校名稱String schoolId = student.getSchoold();student.setSchooldName(schoolMap.getOrDefault(schoolId, new School()).getName());// 籍貫ID → 籍貫名稱String nativePlaceId = student.getNativePlace();student.setNativePlaceName(nativePlaceMap.getOrDefault(nativePlaceId, new NativePlace()).getName());}
}// 輔助方法:簡化字段添加邏輯
private void addIfNotEmpty(Set<String> set, String value) {if (StringUtil.isNotEmpty(value)) {set.add(value);}
}// 輔助方法:將列表轉換為Map(避免重復代碼)
private <T> Map<String, T> toMap(List<T> list, Function<T, String> keyExtractor) {return list.stream().collect(Collectors.toMap(keyExtractor, Function.identity(), (existing, replacement) -> existing));
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/78846.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/78846.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/78846.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Spring Boot 中集成 Disruptor_高性能事件處理框架

1. 引言 1.1 什么是 Disruptor Disruptor 是一個高性能的事件處理框架,廣泛應用于金融交易系統、日志記錄、消息隊列等領域。它通過無鎖機制和環形緩沖區(Ring Buffer)實現高效的事件處理,具有極低的延遲和高吞吐量的特點。 1.2 為什么使用 Disruptor 高性能:通過無鎖機…

Java中equals與 “==” 的區別

首先我們要掌握基本數據類型和引用類型的概念 基本數據類型&#xff1a; byte&#xff0c;short&#xff0c;int,long,float,double,boolean,char 基本的八大數據類型都各自封裝著包裝類&#xff0c;提供了更多的方法&#xff0c;并且都是引言類型 引用類型&#xff1a; 引…

青少年編程與數學 02-016 Python數據結構與算法 11課題、分治

青少年編程與數學 02-016 Python數據結構與算法 11課題、分治 一、分治算法的基本原理二、分治算法的實現步驟快速排序算法代碼示例&#xff08;Python&#xff09; 三、分治算法的復雜度分析四、分治算法的優缺點優點&#xff1a;缺點&#xff1a; 五、分治算法的應用&#xf…

RFID技術概覽

一、RFID技術定義 RFID&#xff08;Radio Frequency Identification&#xff0c;射頻識別&#xff09; 是一種通過無線電信號識別目標對象并獲取相關數據的非接觸式自動識別技術。它利用射頻信號的空間耦合&#xff08;電感或電磁耦合&#xff09;實現無物理接觸的信息傳遞與目…

【C++游戲引擎開發】第13篇:光照模型與Phong基礎實現

一、Phong模型數學原理 1.1 光照疊加公式 L = k a I a + k d I d max ? ( 0 , n ? l ) + k s I s max ? ( 0 , r ? v ) α L = k_a I_a + k_d I_d \max(0, \mathbf{n} \cdot \mathbf{l}) + k_s I_s \max(0, \mathbf{r} \cdot \mathbf{v})^\alpha L=ka?Ia?+kd?Id?max(0…

C語言中數組與指針:差異、應用及深度剖析

在C語言編程領域中&#xff0c;數組和指針是極為重要的概念&#xff0c;它們各自扮演著獨特的角色&#xff0c;既有著緊密的聯系&#xff0c;又存在顯著的區別。深入理解它們的作用與差異&#xff0c;是掌握C語言編程的關鍵。 數組&#xff1a;數據的有序集合 數組是一組具有相…

【AI大模型】大模型RAG技術Langchain4j 核心組件深入詳解

目錄 一、前言 二、Langchain4j概述 2.1 Langchain4j 是什么 2.2 Langchain4j 主要特點 2.3 Langchain4j 核心組件 2.4 Langchain4j 核心優勢 三、Langchanin4j組件應用實戰 3.1 前置準備 3.1.1 導入如下依賴 3.1.2 獲取apikey 3.1.3 獲取官方文檔 3.2 聊天組件 3.…

Web滲透之文件包含漏洞

文件包含漏洞原理 1、源代碼 <?php$filename $_GET[filename]; include $filename; //或include_once,require,require_onceecho "歡迎來到PHP的世界.";?> 2、利用條件 php.ini中alllow_url_fopenOn(默認開啟)和allow_url_includeOff(默認關閉)要開啟…

MySQL 中查詢 VARCHAR 類型 JSON 數據的

在數據庫設計中&#xff0c;有時我們會將 JSON 數據存儲在 VARCHAR 或 TEXT 類型字段中。這種方式雖然靈活&#xff0c;但在查詢時需要特別注意。本文將詳細介紹如何在 MySQL 中有效查詢存儲為 VARCHAR 類型的 JSON 數據。 一、問題背景 當 JSON 數據存儲在 VARCHAR 列中時&a…

路由器開啟QOS和UPNP的作用

QOS 的作用 保障關鍵業務帶寬&#xff1a;可根據網絡應用的重要性分配帶寬。比如在家庭網絡中&#xff0c;當多人同時使用網絡時&#xff0c;將視頻會議等實時性要求高的關鍵業務設置為高優先級&#xff0c;確保其能獲得足夠帶寬&#xff0c;避免卡頓&#xff0c;而文件下載等…

5G網絡下客戶端數據業務掉線頻繁

MCPTT&#xff08;Mission Critical Push-to-Talk&#xff09;客戶端的日志&#xff0c;和界面在待機狀態下&#xff08;即沒有做通話等業務操作&#xff09;&#xff0c;會頻繁提示“離線”。 主要先看有沒有丟網&#xff0c;UL BLER有沒有問題。確認沒有問題。看到業務信道釋…

使用Python和Matplotlib可視化字體輪廓:從路徑數據到矢量圖形

引言 字體設計和矢量圖形處理是編程中一個有趣且實用的領域。通過Python的matplotlib庫&#xff0c;我們可以輕松將字體輪廓的路徑數據轉換為直觀的矢量圖形。本文將帶你一步步實現這一過程&#xff0c;并解析代碼細節&#xff0c;幫助你理解如何將復雜的路徑指令轉化為可視化…

4.13日總結

javafx中實現發送qq郵箱驗證碼: 手動導入jar包方法&#xff1a; 第一步&#xff1a;開啟QQ郵箱的 POP3/IMAP 或者 SMTP/IMAP 服務 打開qq郵箱&#xff08;電腦端&#xff09;&#xff0c;找到設置里的賬號與安全的安全設置&#xff0c;往下滑就可以找到 POP3/IMAP 或者 SMTP…

智慧鄉村數字化農業全產業鏈服務平臺建設方案PPT(99頁)

1. 農業全產業鏈概念 農業全產業鏈是依托數字化、電子商務、云計算等技術&#xff0c;整合規劃咨詢、應用軟件設計與開發等服務&#xff0c;推動農業產業升級和價值重塑&#xff0c;構建IT產業融合新生態。 2. 產業鏈技術支撐 利用云計算、大數據、區塊鏈等技術&#xff0c;為…

k8s的配置文件總結

在 Kubernetes 中&#xff0c;配置文件 是定義集群資源的核心&#xff0c;通常以 YAML 或 JSON 格式編寫。以下是 Kubernetes 中關鍵的配置文件類型及其作用&#xff1a; 1. 核心工作負載配置 (1) Deployment ? 用途&#xff1a;定義無狀態應用的 Pod 副本管理策略&#xff…

STM32(基于標準庫)

參考博客&#xff1a;江科大STM32筆記 Stm32外設 一、GPIO 基礎 GPIO位結構 I/O引腳的保護二極管是對輸入電壓進行限幅的上面的二極管接VDD, 3.3V,下面接VSS, 0V&#xff0c;當輸入電壓 >3.3V 那上方這個二極管就會導通&#xff0c;輸入電壓產生的電流就會大部分充入VD…

為什么我們需要if __name__ == __main__:

[目錄] 0.前言 1.什么是 __name__&#xff1f; 2.if __name__ __main__: 的作用 3.為何Windows更需if __name__ &#xff1f;前言 if __name__ __main__: 是 Python 中一個非常重要的慣用法&#xff0c;尤其在使用 multiprocessing 模塊或編寫可導入的模塊時。它的作用是區分…

速盾:高防CDN的原理和高防IP一樣嗎?

隨著互聯網的發展&#xff0c;網絡安全威脅日益嚴重&#xff0c;尤其是DDoS攻擊、CC攻擊等惡意行為&#xff0c;給企業帶來了巨大的風險。為了應對這些挑戰&#xff0c;許多企業開始采用高防CDN&#xff08;內容分發網絡&#xff09;和高防IP作為防御措施。盡管兩者都能提供一定…

《算法筆記》3.6小節——入門模擬->字符串處理

1009 說反話 #include <cstdio>int main() {char sen[80][80];int num0;while(scanf("%s",sen[num])!EOF){num;}for (int i num-1; i > 0; --i) {printf("%s ",sen[i]);}printf("%s\n",sen[0]);return 0; }字符串連接 #include <io…

供應鏈業務-供應鏈全局觀(三)- 供應鏈三流的集成

概述 供應鏈的全局觀的全兩篇文章主要描述了供應鏈的基礎概念和供應鏈的協作和集成問題。 供應鏈業務-供應鏈全局觀&#xff08;一&#xff09;定義了什么是供應鏈和供應鏈管理。 所謂供應鏈就是把采購進來的東西&#xff0c;通過自身的生成加工&#xff0c;進行增值服務&am…