프론트 에서 들 려 오 는 새로운 데이터 와 데이터베이스 에 있 는 오래된 데이터 비교 업데이트 알고리즘
질문:
데이터베이스 에 데 이 터 를 저장 하고 프론트 데스크 업데이트 작업 에서 새로운 데 이 터 를 보 내 왔 습 니 다.어떻게 차 이 를 비교 하여 업 데 이 트 를 진행 합 니까?예:
프론트 데스크 에서 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);
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.