From 26f163a9782ea92a814d05555a2ad145079a3cc5 Mon Sep 17 00:00:00 2001 From: kaiyu <404897439@qq.com> Date: Fri, 14 May 2021 09:08:41 +0800 Subject: [PATCH] screen-manage 因子数据添加缓存 --- screen-common/src/main/java/com/moral/constant/Constants.java | 1 + screen-common/src/main/java/com/moral/constant/RedisConstants.java | 6 ++++++ screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java | 43 +++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 50 insertions(+), 0 deletions(-) diff --git a/screen-common/src/main/java/com/moral/constant/Constants.java b/screen-common/src/main/java/com/moral/constant/Constants.java index 1703fcc..07e4cb1 100644 --- a/screen-common/src/main/java/com/moral/constant/Constants.java +++ b/screen-common/src/main/java/com/moral/constant/Constants.java @@ -95,4 +95,5 @@ public static final String SYSTEM_DICT_TYPE_UNIT = "unit"; + } diff --git a/screen-common/src/main/java/com/moral/constant/RedisConstants.java b/screen-common/src/main/java/com/moral/constant/RedisConstants.java index cb18099..2578c67 100644 --- a/screen-common/src/main/java/com/moral/constant/RedisConstants.java +++ b/screen-common/src/main/java/com/moral/constant/RedisConstants.java @@ -22,4 +22,10 @@ * ������List<sysDictType>������ * */ public static final String DICT_TYPE_KEY = "dict_type"; + + /* + * ������ redis������key + * ������Map<Integer,Sensor>������ + * */ + public static final String SENSOR_KEY = "sensor"; } diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java index fae31a5..14da511 100644 --- a/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java +++ b/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java @@ -10,8 +10,10 @@ import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.moral.api.util.LogUtils; import com.moral.constant.Constants; +import com.moral.constant.RedisConstants; import com.moral.constant.ResponseCodeEnum; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.ObjectUtils; @@ -42,6 +44,9 @@ @Autowired LogUtils logUtils; + + @Autowired + RedisTemplate redisTemplate; @Override @Transactional @@ -75,6 +80,8 @@ logUtils.saveOperationForManage(request,content,Constants.INSERT_OPERATE_TYPE); resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode()); resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg()); + //������������ + refreshCache(); return resultMap; } @@ -129,6 +136,8 @@ logUtils.saveOperationForManage(request,content,Constants.UPDATE_OPERATE_TYPE); resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode()); resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg()); + //������������ + refreshCache(); return resultMap; } @@ -193,6 +202,8 @@ logUtils.saveOperationForManage(request,content,Constants.DELETE_OPERATE_TYPE); resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode()); resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg()); + //������������ + refreshCache(); return resultMap; } @@ -235,4 +246,36 @@ resultMap.put("totalPageNumber",totalPageNumber); return resultMap; } + + public Map<String,Sensor> getAllSensorFromCache(){ + Map<String,Sensor> sensors = redisTemplate.opsForHash().entries(RedisConstants.SENSOR_KEY); + if(ObjectUtils.isEmpty(sensors)) + return getAllSensorFromDB(); + return sensors; + } + + private Map<String,Sensor> getAllSensorFromDB(){ + QueryWrapper<Sensor> wrapper = new QueryWrapper<>(); + wrapper.eq("is_delete",Constants.NOT_DELETE); + List<Sensor> sensors = sensorMapper.selectList(wrapper); + Map<String,Sensor> result = new HashMap<>(); + for (Sensor sensor : sensors) { + result.put(sensor.getCode(),sensor); + } + //������������ + refreshCache(result); + return result; + } + + private void refreshCache(){ + Map<String, Sensor> sensors = getAllSensorFromDB(); + refreshCache(sensors); + } + + private void refreshCache(Map<String,Sensor> sensors){ + //������������ + redisTemplate.delete(RedisConstants.SENSOR_KEY); + //������������ + redisTemplate.opsForHash().putAll(RedisConstants.SENSOR_KEY,sensors); + } } -- Gitblit v1.8.0