从数据库中查询出记录,然后以对象的形式封装到List中去。此时假设有两个条件A和B,满足A的记录集和为ListA,满足B的记录集合为ListB,现在要将ListA和ListB合并为一个List,注意ListA和ListB中可能有重复的记录(因为可能某条记录即满足条件A又满足条件B),要过滤掉重复的记录。
方法过程:假设List中存放的对象都是Order对象,属性orderId用于标识一个唯一的Order对象
- List<order></order> list = new ArrayList<order></order>();
-
- if(ListA!=null){
-
- Iterator it= ListA.iterator();
-
- while(it.hasNext()){
-
- list.add((Order)it.next());
-
- }
-
- }
-
- if(ListB!=null){
-
- Iterator it= ListB.iterator();
-
- while(it.hasNext()){
-
- Order o=(Order)it.next();
-
- if(list.contains(o))
-
- list.add(o);
-
- }
-
- }
-
首先将ListA中的对象全部装入到list中,然后在装入ListB中对象的
时候对ListB中的每个元素进行一下判断,看list中是否已存在该元素,这里我们使用List接口的contains()方法。它的原理是这样的:如上例中的 list.contains(o),系统会对list中的每个元素e调用o.equals(e),方法,加入list中有n个元素,那么会调用n次o.equals(e),只要有一次o.equals(e)返回了true,那么list.contains(o)返回true,否则返回false。因此为了很好的使用contains()方法,我们需要重新定义下Order类的equals方法,根据我们的业务逻辑,如果两个Order对象的orderId相同,那么我们认为它们代表同一条记录,于是equals方法定义如下:
- public boolean equals(Object obj) {
-
- if (this == obj)
-
- return true;
-
- if (obj == null)
-
- return false;
-
- if (getClass() != obj.getClass())
-
- return false;
-
- final Order other = (Order) obj;
-
- if(this.getOrderid()!=other.getOrderid())
-
- return false;
-
- return true;
-
- }
-
这样只要ListB中有一条记录的orderId和list中的某条记录的orderId
相等,就认为该记录已存在,不再将它放入list,这样就避免了重复记录的存在。
分享到:
相关推荐
遇到合并两个LIST的问题,自己用JAVA语言写出来,将代码粘贴成文档
合并前第一个文件和第二个文件 代码 file1 = open(my.txt,r) file2 = open(ids.txt,r) file1_lists =file1.readlines() file2_lists =file2.readlines() file3_list = [] file4_list = [] for i in file1_lists: ...
Java中 List《map》把里面map中某个key相同记录的其他key 的 value 合并 Java中 List《map》把里面map中某个key相同记录的其他key 的 value 合并
python中,list这种数据结构很常用到,如果两个或者多个list结构相同,内容类型相同,我们通常会将两个或者多个list合并成一个,这样我们再循环遍历的时候就可以一次性处理掉了
Java将2个List集合合并到一个List里面并排序工具类 1、Java编程资源,定义了一个名为`ListMerger`的工具类,主要包含一个名为`mergeAndSortLists`的静态方法。此方法用于将两个已经根据时间顺序排列的List合并成一...
合并两个链表:设A与B分别为两个带有头结点的有序循环链表(所谓有序是指链接点按数据域值大小链接,本题不妨设按数据域值从小到大排列),list1和list2分别为指向两个链表的头指针。请写出将这两个链表合并为一个...
今天小编就为大家分享一篇python实现两个字典合并,两个list合并,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
将两个有序链表合并为一个新的有续链表并返回。新链表是通过拼接给定的两个链表的所有节点做成的。 思路: 1、如果给定的两条链表中有一条为空,返回另一条即可 2、若两条链表都不为空,则在两条链表中选择较小的...
两个有序链表的合并pta 解法1:迭代思路:首先创建一个 pre_head 节点,并用 cur 指针指向它,这个 pre_head 用于之后指向 list1 和 list2 中的第一个节点,而不是指向新生成的节点,因此空间复杂度为O(1)。接下来...
网上找了好久,都没有具体用sortedlist合并excel的实例,自己写了一个,还用了vsto,希望能给初学者提供帮助>.
本文实例讲述了python实现合并多个list及合并多个django QuerySet的方法。分享给大家供大家参考,具体如下: 在用python或者django写一些小工具应用的时候,有可能会遇到合并多个list到一个 list 的情况。单纯从技术...
示例 2:输出:[]示例 3:输出:[]* Definition for singly-linked list.//以合并两个有序链表为基础ListNode*
主要介绍了详解Java8合并两个Map中元素的正确姿势,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
本文实例讲述了Python实现合并两个列表的方法。分享给大家供大家参考,具体如下: 浏览博客看到一个问题:如何合并两个列表,今天就来探讨一下。 方法一 最原始,最笨的方法,分别从两个列表中取出所有的元素,再放...
主要介绍了java 实现多个list 合并成一个去掉重复的案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
要合并两个有序链表,可以按照以下步骤进行: 1. 创建一个新的链表作为合并后的结果。 2. 遍历两个有序链表,比较它们的节点值。 3. 每次选择较小的节点值,将其插入到新链表中,并移动指针到下一个节点。 4. 当...
System.out.println("合并前值:>>>>>>>>>>>>>>>>>>>>>>>>>>>>>"+lst.size()); printLst(lst); // UserBean bbb=null; for(int i=0;i();i++) { UserBean b=(UserBean)lst.get(i); String s=b....
我就废话不多说了,直接上代码吧!...以上这篇python实现两个一维列表合并成一个二维列表就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持软件开发网。 您可能感兴趣的文章:python二维
今天小编就为大家分享一篇关于判断List和Map是否相等并合并List中相同的Map,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧