java 取出集合前两个数据库_【Java】获取两个List中不同的数据(效率非常不错)-Go语言中文社区...

项目背景

刚好项目要快速对比两张表的不同数据,但是提供的是id的列表(list),另外在数据库中,所以这里想出了一个办法,先从数据库中找出有的数据in(sql)出来先,然后用代码匹对,因为这里要查出提供的id列表哪些是多余的数据,所以代码返回多余id的list

结果:

1、list1中有97277条数据,list2中有37894条数据,两个list进行对比找出不同的数据共60000条左右,用时:0.051秒

2、list1中有97277条数据,list2中有97067条数据,两个list进行对比找出不同的数据共288条,用时:0.06秒

下面的方法是对比两个list相互不同的数据

也可以删除红色字的代码做成list1比list2多出多少数据

public static List getDiffrent(List list1, List list2){

Map map = new HashMap(list1.size()+list2.size());

List diff = new ArrayList();

List maxList = list1;

List minList = list2;

if(list2.size()>list1.size()){

maxList = list2;

minList = list1;

}

for (String string : maxList){

map.put(string, 1);

}

for (String string : minList){

Integer cc = map.get(string);

if(cc!=null){

map.put(string, ++cc);

continue;

}

map.put(string, 1);

}

for(Map.Entry entry:map.entrySet()){

if(entry.getValue()==1)

{

diff.add(entry.getKey());

}

}

return diff;

}

有人回复说不行,我再补充main方法,(受不了不给测试方法就说不行的人)

public static void main(String[] args) {

List list1 =new ArrayList();

for(int i=1;i<10;i++) {

list1.add(i+"");

}

List list2 =new ArrayList();

for(int i=5;i<10;i++) {

list2.add(i+"");

}

List list3 =getDiffrent(list1,list2);

List list4 =getDiffrent(list2,list1);

System.out.println(list1);

System.out.println(list2);

System.out.println("不同的值:"+list3);

System.out.println("不同的值:"+list4);

}

结果如图

d95c2ba93269b895dc46f7f102539dbd.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值