• 简介 (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. [一本通1677/JZOJ1217/CJOJ1101]软件开发 题解

    题目描述 一个软件开发公司同时要开发两个软件,并且要同时交付给用户,现在公司为了尽快完成这一任务,将每个软件划分成\(m\)个模块,由公司里的技术人员分工完成,每个技术人员完成同一软件的不同模块的所用 ...

  2. [一本通1700]PFS集合

    题目描述 有一种特殊的集合叫做PFS(Prefix Free Set)集合. 一个PFS集合由若干字符串构成,且不存在一个字符串是另一个字符串的前缀.空集也被看作是PFS集合. 例如 {\(" ...

  3. C++调用Python-5:调用Python函数,传参数字+字符串

    # mytest.py def myjoin(a, b): print("num a + str b") return f"{a}=={b}" #include ...

  4. 新手真的别再用过时的jenkins freestyle了,10分钟教你搞定快速编写jenksinfile,快速离线调试

    Pipeline是一套运行于jenkins上的工作流框架,将原本独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂流程编排与可视化.它通过Domain Specific Langua ...

  5. Java多线程之Callable和Future

    Java多线程之Callable和Future 本篇说明的是Callable和Future,它俩很有意思的,一个产生结果,一个拿到结果. Callable接口类似于Runnable,从名字就可以看出来 ...

  6. c# mvc action 跳转方式

    前言 c# 的mvc 有很多的action跳转方式,在此总结一下具体的跳转方法. 这里不用去记,而是知道能怎么做,为什么能这样做,重在思考. 正文 一.RedirectToAction("I ...

  7. ActiveMQ c# 系列——进阶实例(三)

    前言 前面介绍了基本的消费者和生产者,那么看下他们之间有什么其他的api. 正文 消费者设置等待时间 生产者生产了5条消息 改一下消费者. static void Main(string[] args ...

  8. 使用树莓派远程控制灯继电器开关,dht11温湿度网页显示,树莓派物联网

    前段时间使用esp8266搞了个智能家居,通过网页控制,但是没有办法实现远程控制,只能局域网控制,因为我没有平台,使用机制云等平台还需要开发app 使用chatgpt生成的main.py程序 from ...

  9. Jenkins集成GitLab的正确姿势,实现Git代码提交触发CI/CD

    ❝ jenkins和gitlab是目前DevOps工具链中最常见的,抛开gitlab-ci不谈,gitlab代码提交触发jenkins流水线是最经典的搭配. 这里就介绍下如何配置实现jenkins和g ...

  10. 力扣610(MySQL)-判断三角形(简单)

    题目: 表: Triangle 写一个SQL查询,每三个线段报告它们是否可以形成一个三角形. 以 任意顺序 返回结果表. 查询结果格式如下所示. 示例1:  解题思路: 判断是否形成三角形的准则是:两 ...