先看網絡上,博客經常出現的錯誤代碼:
for(ABatchAddCheckVO aBatchAddCheckVO : addList){ dto.put("aac001",aBatchAddCheckVO.getAac001());//設置人員編號 //由於sql語句使用union查詢_sjql和ac4,如果2個表都有記錄,就會存在重復,需要去重 List<Map> list = aFQService.getBatchAc5_SJQL(dto); //list數據去重——冒泡去重 for(int i = 0; i < list.size(); i++){ //得到list中每一個map Map map= list.get(i); for (int j = 1; j < list.size(); j++) { Map map2= list.get(j); if (map.get("qlbzlb").equals(map2.get("qlbzlb"))) { list.remove(j); continue; } } } if(ValidateUtil.isNotEmpty(list)){ succList.addAll(list);// 把查出來的標識數據,直接存到成功列表中 }else{ errList.add(aBatchAddCheckVO);//沒有查出來,就是錯誤數據 } }
一樣的:
if ("2".equals(dto.getAsString("czfs"))) { List<Key> list = JSONObject.parseArray(dto.getAsString("list"), Key.class); List<ADetailVO> aDetailVOList = new ArrayList<>(); //需要對list根據aac001去重,一個aac001會有多條記錄,后台方法支持,根據一個aac001查出多條問題記錄, // 如果不根據aac001去重,就會出現一個人重復插入事件表和明細表問題 //list數據去重——冒泡去重 for(int i = 0; i < list.size(); i++){ //得到list中每一個map Map map= list.get(i); for (int j = 1; j < list.size(); j++) { Map map2= list.get(j); if (map.get("aac001").equals(map2.get("aac001"))) { list.remove(j); continue; } } }
注意:
上述代碼有bug,不是冒泡排序,會出問題,使用時,會過濾掉(即:remove 掉一半的數據)
更改如下:
//需要對list根據aac001去重,一個aac001會有多條記錄,后台方法支持,根據一個aac001查出多條問題記錄, // 如果不根據aac001去重,就會出現一個人重復插入事件表和明細表問題 //list數據去重——冒泡去重 for(int i = 0; i < list.size() - 1; i++){ //得到list中每一個map Map map= list.get(i); for(int j = list.size() - 1; j > i; j--){ Map map2= list.get(j); if (map.get("aac001").equals(map2.get("aac001"))) { list.remove(j); continue; } } }
