diff --git a/opsli-modulars/opsli-modulars-system/src/main/java/org/opsli/modulars/system/dict/service/impl/DictDetailServiceImpl.java b/opsli-modulars/opsli-modulars-system/src/main/java/org/opsli/modulars/system/dict/service/impl/DictDetailServiceImpl.java index b94ac45d..4f06baf3 100644 --- a/opsli-modulars/opsli-modulars-system/src/main/java/org/opsli/modulars/system/dict/service/impl/DictDetailServiceImpl.java +++ b/opsli-modulars/opsli-modulars-system/src/main/java/org/opsli/modulars/system/dict/service/impl/DictDetailServiceImpl.java @@ -42,7 +42,9 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.Collection; +import java.util.HashSet; import java.util.List; +import java.util.Set; /** @@ -81,30 +83,23 @@ public class DictDetailServiceImpl extends CrudServiceImpl listByTypeCode = this.findListByTypeCode(ret.getTypeCode()); + if(listByTypeCode != null && listByTypeCode.size() > 0){ + List dictWrapperList = Lists.newArrayListWithCapacity(listByTypeCode.size()); + for (DictDetailModel dictDetailModel : listByTypeCode) { + DictWrapper dictWrapperModel = new DictWrapper(); + dictWrapperModel.setTypeCode(dictDetailModel.getTypeCode()); + dictWrapperModel.setDictName(dictDetailModel.getDictName()); + dictWrapperModel.setDictValue(dictDetailModel.getDictValue()); + dictWrapperList.add(dictWrapperModel); + } + // 删除缓存 + DictUtil.delAll(ret.getTypeCode()); + // 广播缓存数据 - 通知其他服务器同步数据 + redisPlugin.sendMessage( + DictMsgFactory.createMsg(dictWrapperList, CacheType.DELETE) + ); + } } return ret; @@ -132,29 +127,23 @@ public class DictDetailServiceImpl extends CrudServiceImpl listByTypeCode = this.findListByTypeCode(oldModel.getTypeCode()); + if(listByTypeCode != null && listByTypeCode.size() > 0){ + List dictWrapperList = Lists.newArrayListWithCapacity(listByTypeCode.size()); + for (DictDetailModel dictDetailModel : listByTypeCode) { + DictWrapper dictWrapperModel = new DictWrapper(); + dictWrapperModel.setTypeCode(dictDetailModel.getTypeCode()); + dictWrapperModel.setDictName(dictDetailModel.getDictName()); + dictWrapperModel.setDictValue(dictDetailModel.getDictValue()); + dictWrapperList.add(dictWrapperModel); + } + // 删除缓存 + DictUtil.delAll(oldModel.getTypeCode()); + // 广播缓存数据 - 通知其他服务器同步数据 + redisPlugin.sendMessage( + DictMsgFactory.createMsg(dictWrapperList, CacheType.DELETE) + ); + } } return ret; @@ -168,19 +157,26 @@ public class DictDetailServiceImpl extends CrudServiceImpl listByTypeCode = this.findListByTypeCode(dictModel.getTypeCode()); + if(listByTypeCode != null && listByTypeCode.size() > 0){ + List dictWrapperList = Lists.newArrayListWithCapacity(listByTypeCode.size()); + for (DictDetailModel dictDetailModel : listByTypeCode) { + DictWrapper dictWrapperModel = new DictWrapper(); + dictWrapperModel.setTypeCode(dictDetailModel.getTypeCode()); + dictWrapperModel.setDictName(dictDetailModel.getDictName()); + dictWrapperModel.setDictValue(dictDetailModel.getDictValue()); + dictWrapperList.add(dictWrapperModel); + } + // 删除缓存 + DictUtil.delAll(dictModel.getTypeCode()); + // 广播缓存数据 - 通知其他服务器同步数据 + redisPlugin.sendMessage( + DictMsgFactory.createMsg(dictWrapperList, CacheType.DELETE) + ); + } } return ret; } @@ -192,19 +188,26 @@ public class DictDetailServiceImpl extends CrudServiceImpl listByTypeCode = this.findListByTypeCode(dictModel.getTypeCode()); + if(listByTypeCode != null && listByTypeCode.size() > 0){ + List dictWrapperList = Lists.newArrayListWithCapacity(listByTypeCode.size()); + for (DictDetailModel dictDetailModel : listByTypeCode) { + DictWrapper dictWrapperModel = new DictWrapper(); + dictWrapperModel.setTypeCode(dictDetailModel.getTypeCode()); + dictWrapperModel.setDictName(dictDetailModel.getDictName()); + dictWrapperModel.setDictValue(dictDetailModel.getDictValue()); + dictWrapperList.add(dictWrapperModel); + } + // 删除缓存 + DictUtil.delAll(dictModel.getTypeCode()); + // 广播缓存数据 - 通知其他服务器同步数据 + redisPlugin.sendMessage( + DictMsgFactory.createMsg(dictWrapperList, CacheType.DELETE) + ); + } } return ret; } @@ -226,16 +229,24 @@ public class DictDetailServiceImpl extends CrudServiceImpl 0){ List dictWrapperModels = Lists.newArrayListWithCapacity(list.size()); - // 删除缓存 + Set typeCodes = new HashSet<>(); + // 封装数据 for (SysDictDetail sysDictDetail : list) { DictWrapper dictWrapperModel = new DictWrapper(); dictWrapperModel.setTypeCode(sysDictDetail.getTypeCode()); dictWrapperModel.setDictName(sysDictDetail.getDictName()); dictWrapperModel.setDictValue(sysDictDetail.getDictValue()); - // 删除缓存 - DictUtil.del(dictWrapperModel); + dictWrapperModels.add(dictWrapperModel); + + typeCodes.add(dictWrapperModel.getTypeCode()); } + + // 删除缓存 + for (String typeCode : typeCodes) { + DictUtil.delAll(typeCode); + } + // 广播缓存数据 - 通知其他服务器同步数据 redisPlugin.sendMessage( DictMsgFactory.createMsg(dictWrapperModels, CacheType.DELETE) @@ -270,16 +281,24 @@ public class DictDetailServiceImpl extends CrudServiceImpl 0){ List dictWrapperModels = Lists.newArrayListWithCapacity(list.size()); - // 删除缓存 + Set typeCodes = new HashSet<>(); + // 封装数据 for (SysDictDetail sysDictDetail : list) { DictWrapper dictWrapperModel = new DictWrapper(); dictWrapperModel.setTypeCode(sysDictDetail.getTypeCode()); dictWrapperModel.setDictName(sysDictDetail.getDictName()); dictWrapperModel.setDictValue(sysDictDetail.getDictValue()); - // 删除缓存 - DictUtil.del(dictWrapperModel); + dictWrapperModels.add(dictWrapperModel); + + typeCodes.add(dictWrapperModel.getTypeCode()); } + + // 删除缓存 + for (String typeCode : typeCodes) { + DictUtil.delAll(typeCode); + } + // 广播缓存数据 - 通知其他服务器同步数据 redisPlugin.sendMessage( DictMsgFactory.createMsg(dictWrapperModels, CacheType.DELETE)