網站首頁 編程語言 正文
業務場景:定時任務同步中間表數據到業務表,如果中間表中存在相同維度的多條數據(未創建唯一索引),取最新一條數據,并對查詢的中間表數據進行更新。
方式1
?
// 根據結果表唯一索引分組,取中間表重復最新一條
? ? ? ? Map<String, List<MidDeliveryAreaConfigFresh>> mapGroup = list.stream().collect(Collectors.groupingBy(v ->
? ? ? ? ? ? ? ? v.getDcCode() + v.getBigCategoryCode() + v.getSmallCategoryCode() + v.getProductCode() + v.getStockLoc()));
? ? ? ? List<MidDeliveryAreaConfigFresh> resultList = mapGroup.values().stream().map(listv -> listv.get(listv.size() - 1)).collect(Collectors.toList());
方式2
List<MidDeliveryAreaConfigFresh> resultList = list.stream().collect(Collectors.groupingBy(v -> new StringBuilder().append(v.getDcCode())
?? ??? ?.append(v.getBigCategoryCode()).append(v.getSmallCategoryCode()).append(v.getProductCode()).append(v.getStockLoc())))
?? ??? ?.values().stream().map(listv -> listv.get(listv.size() - 1));
方式2SonarLint檢測工具不通過,方式1對方式2進行了拆分優化。
方式3,更詳細拆分
? Map<String, List<MidDeliveryAreaFresh>> map = list.stream().collect(Collectors.groupingBy(MidDeliveryAreaFresh::getDeliveryAreaCode));
? ? ? ? List<List<MidDeliveryAreaFresh>> groupList = map.values().stream().collect(Collectors.toList());
? ? ? ? List<MidDeliveryAreaFresh> resultList = groupList.stream().map(listv -> listv.get(listv.size() - 1)).collect(Collectors.toList());
?
?
原文鏈接:https://blog.csdn.net/qq_18671415/article/details/120643395
相關推薦
- 2022-05-08 python添加列表元素append(),extend()及?insert()_python
- 2022-09-09 Nginx配置解決NetCore的跨域問題_nginx
- 2022-12-21 Android?全局通知彈窗示例分析詳解_Android
- 2022-03-19 Docker匿名掛載和具名掛載的具體使用_docker
- 2022-09-02 Python常用編碼的區別介紹_python
- 2022-10-31 C#實現HTTP訪問類HttpHelper的示例詳解_C#教程
- 2022-12-01 C/C++細數宏與函數有那些區別_C 語言
- 2023-05-24 python實現對AES加密的視頻數據流解密的方法_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支