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;
}