set集合去掉重複數據

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;
    }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章