您的位置:首页 > 其它

set集合去掉重复数据

2016-08-25 22:08 232 查看
1.应用场景:向数据库导入数据,数据库已存在是数据不导入

2.解决方案:将数据已存在的数据放入set集合,要导入的数据也放入另一个集合list,遍历list每条数据,获取数据库没有的数据,即为要导入的数据。

public static List<Map<String, Object>> isHaveStock(List<Map<String, Object>> oldList, List<Map<String, Object>> newList) {
//1.先将数据库已经存在数据放到set集合
Set<String> oldIds = new HashSet<String>();
if(oldList !=null){// 数据库已经存在的数据
for (int i = 0; i < oldList.size(); i++) {
oldIds.add(oldList.get(i).get("stock_code").toString());
}
}

//2.比较是否存在
List<Map<String, Object>> infoList = new ArrayList<Map<String, Object>>();
if(newList!=null){//excel的数据
for (int i = 0; i < newList.size(); i++) {
Map<String, Object> m = newList.get(i);
if (!oldIds.contains(m.get("stock_code"))) {//数据库没有包含excel中数据
infoList.add(m);
}
}
}
return infoList;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  遍历