• 简介 (Introduction):

    • 背景
      需要对数据进行拼接,拼接的数据是存在两个不同的表中,但是,拼接后要作为一个对象显示,但是,这样的对象又是多个的.
    • 结构图
      数据库模型

      id name
      10086 zhangsan
      10087 lisi
id work
10086 teacher
10087 programmer

需要结果

id name work
10086 zhangsan

teacher

10087 lisi

programmer

  • 核心
    因为是在不同的数据库里,所以不能使用sql联合查询,所以只能采用List封装数据和另一个List封装数据拼接成一个结果集

  • 快速上手(Getting Started)

    1.创建测试数据

     1 private static List<SameOr> getDemo1() {
    2
    3
    4 List<SameOr> sameOrList = new ArrayList<>();
    5
    6 SameOr sameOr = new SameOr();
    7 sameOr.setNumber("10086");
    8 sameOr.setName("zhangsan");
    9
    10 SameOr sameOr2 = new SameOr();
    11 sameOr2.setNumber("10087");
    12 sameOr2.setName("lisi");
    13
    14 sameOrList.add(sameOr);
    15 sameOrList.add(sameOr2);
    16
    17 return sameOrList;
    18
    19 }

     1 private static List<SameOr> getDemo2() {
    2
    3
    4 List<SameOr> sameOrList = new ArrayList<>();
    5
    6 SameOr sameOr = new SameOr();
    7 sameOr.setNumber("10086");
    8
    9 sameOr.setSex("0");
    10 sameOr.setWork("programmer");
    11
    12 SameOr sameOr2 = new SameOr();
    13 sameOr2.setNumber("10087");
    14 sameOr2.setSex("1");
    15 sameOr2.setWork("programmer");
    16
    17
    18 sameOrList.add(sameOr);
    19 sameOrList.add(sameOr2);
    20
    21 return sameOrList;
    22
    23 }

    2.创建核心方法
    由于业务跑在线程里,所以,不建议(基本不适用)双重for循环,所以,这里采用Map方式

     1 private static void getCombineDemo2(List<SameOr> demo1, List<SameOr> demo2) {
    2 HashMap<String, SameOr> map = new HashMap<>();
    3
    4 for (SameOr sameOr : demo1) {
    5 map.put(sameOr.getNumber(), sameOr);
    6 }
    7
    8
    9 for (SameOr sameOr : demo2) {
    10 String sameOrNumber = sameOr.getNumber();
    11 SameOr sameOr1 = map.get(sameOrNumber);
    12 if (sameOr1 == null) {
    13 continue;
    14 }
    15
    16 if (StringUtils.isBlank(sameOr.getName())) {
    17 sameOr.setName(sameOr1.getName());
    18 }
    19
    20 if (StringUtils.isBlank(sameOr.getSex())) {
    21 sameOr.setSex(sameOr1.getSex());
    22 }
    23
    24 if (StringUtils.isBlank(sameOr.getWork())) {
    25 sameOr.setWork(sameOr1.getWork());
    26 }
    27
    28
    29 }
    30
    31 }

    3、测试结果

     1         //两个数组合并成一个
    2 List<SameOr> demo1 = getDemo1();
    3 List<SameOr> demo2 = getDemo2();
    4
    5
    6 System.out.println("创建第一个数据:"+new Gson().toJson(demo1));
    7
    8 System.out.println("创建第二个数据:"+new Gson().toJson(demo2));
    9
    10 getCombineDemo2(demo1, demo2);
    11
    12 System.out.println("结果集:"+new Gson().toJson(demo2));

    4、结果展示
    创建第一个数据:

     1 [
    2 {
    3 "number":"10086",
    4 "name":"zhangsan"
    5 },
    6 {
    7 "number":"10087",
    8 "name":"lisi"
    9 }
    10 ]

    创建第二个数据:

     1 [
    2 {
    3 "number":"10086",
    4 "work":"programmer",
    5 "sex":"0"
    6 },
    7 {
    8 "number":"10087",
    9 "work":"programmer",
    10 "sex":"1"
    11 }
    12 ]

    结果集:

     1 [
    2 {
    3 "number":"10086",
    4 "name":"zhangsan",
    5 "work":"programmer",
    6 "sex":"0"
    7 },
    8 {
    9 "number":"10087",
    10 "name":"lisi",
    11 "work":"programmer",
    12 "sex":"1"
    13 }
    14 ]
  • 环境设置 (Prerequisite):

    • 环境
      JDK1.8
    • 配置
      IDEA 2019
    • 存在问题
      暂无

  • 进阶篇 (Advanced):

研究中 ......

两个List合并,List集合中的对象根据某个相同的属性,合并另外属性的更多相关文章

  1. List集合中的对象按照某个字段去重实现

    package com.liying.banana.user; import java.util.ArrayList; import java.util.Comparator; import java ...

  2. Java中删除第一个集合中以某某开头的元素,删除第二个集合中以某某结尾的元素,并合并成一个集合

    import java.util.ArrayList; import java.util.List; public class Test { public static void main(Strin ...

  3. 对list集合中的对象进行排序(转载)

    原文链接:http://blog.csdn.net/veryisjava/article/details/51675036 Collections对List集合中的数据进行排序 有时候需要对集合中的元 ...

  4. java中的ArrayList 使得集合中的对象不重复

    JAVA中的List接口存放的元素是可以重复的,在这个我重写对象里面的equals()方法,让集合里存放的对象不能重复 首先建一个类,在里面的main()方法中实现 list1中存放的是可以重复对象的 ...

  5. 如何对List集合中的对象进行按某个属性排序

    我们在实际的开发工作中,经常会碰到排序的问题,如题,我们如何针对List集合中的某一个属性进行排序 当list集合中的元素类型是我们自定义类型时,有两种对list中的元素进行排序的方法: 方法一 让l ...

  6. Struts2的表单标签还可以为集合中的对象赋值

    •Struts 还允许填充 Collection 里的对象, 这常见于需要快速录入批量数据的场合   代码如下 : TestCollectionAction.java package com.atgu ...

  7. 对List集合中的对象中的某个属性进行排序

    今天在项目中遇到的问题,不能在sql中进行order by.所以将数据库中查询出来的集合,在java代码中进行排序 Collections.sort(list, new Comparator<H ...

  8. List集合中的对象根据属性排序

    集合类List存放的数据,默认是按照放入时的顺序存放的,比如依次放入A.B.C,则取得时候,则也是A.B.C的顺序,实际场景中,有时我们需要根据自定义的规则对List中的元素进行排序,该如何实现呢?看 ...

  9. 对list集合中的对象按照对象的某一属性进行排序

    /**  * 重新对list中的CmsCyUser对象按照最终的票数进行排序  * @param list  */ private void reSort(List list) {   Object[ ...

  10. List集合中的对象比较,取出不同对象

    今天在做金碟系统与我们系统的对接的时候需要做一个客户同步 在同步时,需要比较对象,对查询出的数据库的数据进行比较 for(int i=0;i<list2.size();i++){ if(! li ...

随机推荐

  1. #双指针#洛谷 7405 [JOI 2021 Final] 雪玉

    题目传送门 分析 无论怎样刮风,雪球的相对位置不会改变, 实际上每一个空段都由左右两个雪球瓜分(边界空段除外), 那么按照空段长度从小到大排序,用双指针找到恰好第一个未瓜分的位置 代码 #includ ...

  2. Go 语言之 Maps 详解:创建、遍历、操作和注意事项

    Maps 用于以键值对的形式存储数据值.Maps中的每个元素都是一个键值对.Maps是一个无序且可更改的集合,不允许重复.Maps的长度是其元素的数量.您可以使用 len() 函数来查找长度.Maps ...

  3. SAST-数据流分析方法-理论

    引言 众所周知,数据流分析是实现污点分析的一种常用技术 数据流分析分为过程内的数据流分析与过程间的数据流分析.前者是对一个方法体内的数据流分析,主要是基于CFG分析,不涉及方法调用:后者是基于不同方法 ...

  4. GAN的实现和一些问题

    GAN的学习是一个二人博弈问题,最终目标是达到纳什平衡.对抗指的是生成网络和判别网络的互相对抗.生成网络尽可能生成逼真样本,判别网络则尽可能去判别该样本是真实样本,还是生成的假样本.示意图如下: 生成 ...

  5. UE4中HTC Vive 手柄如何抓取物体

    想知道 HTC Vive 手柄如何抓取物体? HTC Vive 的手柄有许多功能,在游戏里你可以用手柄射箭,可以用手柄拾取木棍等等,但是这些是如何设置的呢?来看看我们的公开课教程吧. 本期教程为上半部 ...

  6. 推荐两款HTTP请求Mock利器

    1.背景 在日常测试过程中或者研发开发过程中,目前接口暂时没有开发完成,测试人员又要提前介入接口测试中,测试人员不仅仅只是简单的编写测试用例,也可以通过一些mock的方法进行来提前根据接口测试的情况进 ...

  7. 重新整理 .net core 实践篇—————应用分层[二十四]

    前言 简单整理一下分层. 正文 应用程序分层,分为: 1.领域模型层 2.基础设施层 3.应用层 4.共享层 共享层 共享层一般包括下面几个类库. 有一个Core 的类库,比如说BLog.Core. ...

  8. python实现不同颜色气球隔开摆放,并且提示不能摆放的情况

    这个是一位隐秘人物让我做的一道题(如标题),我也分享出来了. 首先是成品展示(暂时没有做成可视化界面的样子): 我做的是把所有的气球录入进来,然后利用基础数据结构(字典,数据等)排序等,由于我是初学, ...

  9. 【笔记】go语言--接口

    [笔记]go语言--接口 接口的概念 强类型语言:熟悉接口的概念 弱类型语言:没(少)有接口的概念 接口的详解︰使用Google Guice实现依赖注入 curl 是获取http请求的命令工具 cur ...

  10. 力扣608(MySQL)-树节点(中等)

    题目: 给定一个表 tree,id 是树节点的编号, p_id 是它父节点的 id . 树中每个节点属于以下三种类型之一: 叶子:如果这个节点没有任何孩子节点.根:如果这个节点是整棵树的根,即没有父节 ...