使用stream流合并多个List(根据实体类特定属性合并)

news2024/11/24 6:23:20

开发情景

现有多个List集合,其中都是一样的实体类,这里我想根据实体类的特定属性将它们合并在一起,形成一个最终的List集合。
这里主要用到了Stream流的flatMap方法与reduce方法。

flatMap:可以将多个Stream流合并在一起,形成一个Stream流。
reduce:可以将Stram流中的元素按照规则聚合在一起。

示例

现有广告费表,由于广告费类别不同,所以分开了不同的Excel工作簿Sheet类别导入。
这里需要根据 ASIN+店铺别名+月份(Excel工作簿名称开头提供)将多个集合的数据合并在一起。

数据源

这里要读取与合并的数据是从Excel工作簿的多个Sheet表读取过来的。
在这里插入图片描述

注意:并没有真的使用逻辑删除,这里只不过是为了后期可能用,所以加上了。

create table if not exists amazon_monitor_adfee_real
(
    ID                bigint unsigned auto_increment comment 'ID'
        primary key,
    ASIN              varchar(50)                              not null comment 'ASIN',
    SELLER_CODE       varchar(50)                              not null comment '店铺',
    SELLER_OTHER_CODE varchar(50)                              not null comment '店铺别名',
    DATE_MONTH        varchar(50)                              not null comment '实际广告费时间(月份)yyyy-MM',
    ACTUAL_SP_AD_FEE  decimal(15, 4) default 0.0000            null comment '实际SP广告费',
    ACTUAL_SD_AD_FEE  decimal(15, 4) default 0.0000            null comment '实际SD广告',
    ACTUAL_SB_AD_FEE  decimal(15, 4) default 0.0000            null comment '实际SB广告',
    ACTUAL_DSP_AD_FEE decimal(15, 4) default 0.0000            null comment '实际DSP广告',
    CREATE_USER_ID    varchar(32)                              null comment '创建人',
    CREATE_TIME       datetime       default CURRENT_TIMESTAMP 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1531788.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL的概述与安装

一、数据库的基本概念: 1.1 数据: 1) 描述事物的符号记录称为数据(Data)。数字、文字、图形、图像、声音、档案记录等 都是数据。 2)数据是以“记录”的形式按照统一的格式进行存储的,而不是…

ASA方舟生存飞升计划1.5重置版服务器搭建教程

ASA方舟生存飞升计划1.5重置版服务器搭建教程 大家好我是艾西一个做服务器租用的网络安全工程人员,以前有给大家分享过方舟生存进化的搭建架设教程。方舟这游戏出的时间也很久了,随着时间的推移官方有出新的版本命名为飞升计划,不少的玩家都…

数据库系统概论-第4章 数据库安全性

4.1 数据库安全性概述 4.2 数据库安全性控制 4.3 视图机制 4.4 审计 4.5 数据加密 4.6 其他安全性保护 4.7 小结

SVN修改已提交版本的注释

目录 一、需求分析 二、问题分析 三、解决办法 一、需求分析 ​开发过程中,在SVN提交文件后,发现注释写的不完整或不够明确,想再修改之前的注释文字​。 使用环境: SVN服务器操作系统:Ubuntu 20.04.6 LTS SVN版本&…

linux网络服务学习(2):vsftp

1.什么是vsftp vsftp是linux服务器上的一款使用ftp协议的软件,是linux上使用最广泛的ftp服务端软件 ftp协议是使用明文传输的,很不安全,一般用于局域网内的文件上传、下载 2.vsftp连接类型 ftp连接要用到2个端口:21、20端口。…

Visual Studio 2013 - 重置窗口布局

Visual Studio 2013 - 重置窗口布局 1. Microsoft Visual Studio 2013 - 重置窗口布局References 1. Microsoft Visual Studio 2013 - 重置窗口布局 窗口 -> 重置窗口布局 References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/

HarmonyOS定时器与定时任务

HarmonyOS 的 ArkTS 说白了 就是 TS和JS混合 加了一些新特性的语言 定时任务 就还是用 js代码就OK了 我们代码这样写 Entry Component struct Twox {build() {Row() {Column(){Button("触发定时任务").onClick(()>{setTimeout(()> {console.log(执行)},2000…

Halcon 凹坑检测案例

* 使用元组的方法 ImageFile:[] ImageFile[0]:D:/Halcon/产品上的凹坑检测/1.bmp ImageFile[1]:D:/Halcon/产品上的凹坑检测/2.bmp for Index : 0 to |ImageFile|-1 by 1read_image (Image, ImageFile[Index])* 二值化threshold (Image, Region, 100, 255)* 连通性connection (…

C语言实现流水灯

头文件 #ifndef __LED_H__ #define __LED_H__ #define RCC (*(unsigned int *)0X50000A28) #define GPIOE_MODER (*(unsigned int *)0X50006000) #define GPIOF_MODER (*(unsigned int *)0X50007000) #define GPIOE_OTYPER (*(unsigned int *)0X50006004) #define GPIOE_OSPE…

百度千帆模型初次体验【人工智能】

百度千帆模型初次体验【人工智能】 前言版权推荐百度千帆模型初次体验【人工智能】一、百度智能云平台1.领取代金券2.创建应用3.开通付费 二、SpringBoot1.创建SpringBoot项目2.配置文件3.配置Bean4.编写Util5.测试6.结果 三、问题四、资料 最后 前言 2024-3-20 13:38:33 以下…

亚马逊等跨境电商平台自养号测评的五个核心因素

一、安全稳定的环境系统 尽管市场上存在大量现成的系统和软件包,卖个软件或设备给你,这种基本上都没有解决风控的能力,因此,小编推荐大家还是自己掌握相关技术,避免过度依赖于外部资源,目前,也…

从零到一构建短链接系统(七)

1.convention目录下创建exception目录,并创建AbstractException类, ClientException类,ServiceException类,RemoteException类 /*** 抽象项目中三类异常体系,客户端异常、服务端异常以及远程服务调用异常** see Clien…

第2章 数据处理伦理

思维导图 2.1 引言 简单来说,伦理是建立在是非观念上的行为准则。伦理准则通常侧重于公平、尊重、责任、诚信、质量、可靠性、透明度和信任等方面。 数据处理伦理指如何以符合伦理准则的方式获取、存储、管理、使用和销毁数据。 核心概念:对人的影响、…

sentry-cli - error: Failed to load .sentryclirc file from project path

Xcode 15.2 warning sentry-cli - error: Failed to load .sentryclirc file from project path (/Users/zhuhongwei/Desktop/pandabill/.sentryclirc)推荐一下刚上线的 App 熊猫小账本,里面有用到这篇博客讲的内容 熊猫小账本 一个简洁的记账 App,用于…

第1章 Iceberg简介

1.1 概述 Iceberg是一个面向大型分析数据集的开放表格格式。它为多种计算引擎,如Spark、Trino、PrestoDB、Flink、Hive和Impala,增加了表格功能,使用一种高性能的表格格式,其工作方式就像一个SQL表一样。 在生产环境中&#xff0…

QT网络编程之实现UDP组播发送和接收

推荐一个不错的人工智能学习网站,通俗易懂,内容全面,作为入门科普和学习提升都不错,分享一下给大家:前言https://www.captainbed.cn/ai 一.UDP通信 1.QT中实现UDP通信主要用到了以下类:QUdpSocket、QHost…

SQLiteC/C++接口详细介绍之sqlite3类(十二)

返回目录:SQLite—免费开源数据库系列文章目录 上一篇:SQLiteC/C接口详细介绍之sqlite3类(十一) 下一篇:SQLiteC/C接口详细介绍之sqlite3类(十三) ​37.sqlite3_load_extension 用于在SQLit…

个人网站|基于jsp 技术+ Mysql+Java的个人网站设计与实现(可运行源码+数据库+设计文档)

推荐阅读100套最新项目 最新ssmjava项目文档视频演示可运行源码分享 最新jspjava项目文档视频演示可运行源码分享 最新Spring Boot项目文档视频演示可运行源码分享 2024年56套包含java,ssm,springboot的平台设计与实现项目系统开发资源(可…

DC-2 靶场渗透

环境:kali ip:192.168.157.128 靶机:dc-2 ip:192.168.157.129 确保kali和靶机在NAT模式下 1.nmap ip add #查看kali的IP地址 nmap -sP 192.168.157.0/24 #扫描192.168.157.0这个网段下的存活主机 得到到靶机的IP:192.168.15…

网络编程——预备知识

网络编程——预备知识 🍃套接字🌿什么是套接字🌿套接字的类型🌿套接字的位置 🍃IP🍃端口号Port🍃字节序🍃地址信息结构(结构体类型) 🍃套接字 &a…