프론트 에서 들 려 오 는 새로운 데이터 와 데이터베이스 에 있 는 오래된 데이터 비교 업데이트 알고리즘

1809 단어
업무 중 에 아주 작은 기능 을 만 났 는데 잘 쓰 는 것 이 아직 어렵 다 는 것 을 알 게 되 었 고 하룻밤 의 사 고 를 통 해 성 과 를 기록 했다.
질문:
데이터베이스 에 데 이 터 를 저장 하고 프론트 데스크 업데이트 작업 에서 새로운 데 이 터 를 보 내 왔 습 니 다.어떻게 차 이 를 비교 하여 업 데 이 트 를 진행 합 니까?예:
프론트 데스크 에서 1, 2, 3, 데이터베이스 에 3, 5 가 들 려 왔 습 니 다.데이터베이스 에 1, 2 를 추가 해 야 합 니 다.데이터베이스 에서 5 삭제 하기;기 존 데이터 3 은 변 하지 않 습 니 다.
해결 방법 1:
먼저 데이터베이스 에 있 는 원본 데 이 터 를 모두 비우 고 프론트 데스크 의 데 이 터 를 모두 삽입 합 니 다.
이런 방법 은 간단 하고 이해 하기 쉬 우 며 판단 과 정확성 이다.단점 은 기 존 데이터베이스 데이터 가 많 으 면 중복 삭제 후 증가 해 효율 이 높 지 않다 는 것 이다.
해결 방법 2:
원본 데이터베이스 의 데 이 터 를 조회 하여 삭제 할 목록 으로 합 니 다.
프론트 데스크 에서 들 려 오 는 데 이 터 를 옮 겨 다 니 며 위 에서 삭제 할 목록 을 조회 합 니 다. 존재 한다 면 이 데 이 터 는 데이터베이스 에 보관 해 야 한 다 는 것 을 설명 합 니 다.삭제 할 목록 에서 삭제 합 니 다.존재 하지 않 는 다 면 데이터베이스 에 데 이 터 를 추가 하여 새 목록 에 넣 어야 한 다 는 것 을 설명 합 니 다.
옮 겨 다 니 기 를 완료 한 후 삭제 할 목록 의 데 이 터 를 한꺼번에 삭제 하고 새 목록 의 데 이 터 를 삽입 합 니 다.
List<AppSystem> appSystem_deleteList = appSystemDao.getByAppkey(app
		.getAppkey());
List<AppSystem> appSystem_addList = new ArrayList<AppSystem>();
if (sysStr != null && !"".equals(sysStr)) {
	//   hashmap      
	Map<String, AppSystem> appSystem_searchMap = new HashMap<String, AppSystem>();
	for (AppSystem as : appSystem_deleteList) {
		appSystem_searchMap.put(as.getSystemid().toString(), as);
	}
	//                 
	String[] systemIds = sysStr.split(",");
	for (String systemId : systemIds) {
		if (appSystem_searchMap.containsKey(systemId)) {
			//      ,       ,         
			appSystem_deleteList.remove(appSystem_searchMap
					.get(systemId));
		} else {
			//     ,       
			appSystem_addList.add(new AppSystem(app.getAppkey(), Long
					.parseLong(systemId)));
		}
	}
}
appSystemDao.batchAdd(appSystem_addList);
appSystemDao.batchDelete(appSystem_deleteList);

좋은 웹페이지 즐겨찾기