欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程语言 > java >内容正文

java

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

发布时间:2025/4/5 java 80 豆豆
生活随笔 收集整理的这篇文章主要介绍了 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);

}

结果如图

总结

以上是生活随笔为你收集整理的java 取出集合前两个数据库_【Java】获取两个List中不同的数据(效率非常不错)-Go语言中文社区...的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。