From 52303c8868a7d63238e5ac579c85721306e51a40 Mon Sep 17 00:00:00 2001 From: xufenglei <xufenglei> Date: Wed, 07 Mar 2018 08:52:27 +0800 Subject: [PATCH] 报表 优化 --- src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java | 72 ++++++++++++++++++++++++++++++++++-- 1 files changed, 68 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java b/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java index 79cf204..22c16d9 100644 --- a/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java +++ b/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java @@ -1,8 +1,10 @@ package com.moral.service.impl; import java.util.Arrays; +import java.util.HashMap; import java.util.List; import java.util.Map; +import java.util.stream.Collectors; import javax.annotation.Resource; @@ -10,6 +12,9 @@ import com.moral.common.bean.Constants; import com.moral.common.bean.PageBean; import com.moral.common.util.*; +import com.moral.entity.Device; +import com.moral.mapper.DeviceMapper; +import org.apache.commons.collections.CollectionUtils; import org.springframework.stereotype.Service; import com.moral.entity.MonitorPoint; @@ -23,6 +28,8 @@ @Resource private MonitorPointMapper monitorPointMapper; @Resource + private DeviceMapper deviceMapper; + @Resource RedisUtils redisUtils; private static Class ENTITY_CLASS = MonitorPoint.class; @Override @@ -34,13 +41,14 @@ public List<MonitorPoint> queryWithStateByMap(Map<String, Object> params){ List<MonitorPoint> monitorPointList = monitorPointMapper.selectByMap(params); for(MonitorPoint monitorPoint:monitorPointList){ - loadStateFromRedis(monitorPoint); + Integer state = getStateFromRedis(monitorPoint.getId()); + monitorPoint.setState(state); } return monitorPointList; } - private void loadStateFromRedis(MonitorPoint monitorPoint){ + private Integer getStateFromRedis(Integer monitorPointId){ StringBuilder key = new StringBuilder(); - key.append("*_").append(monitorPoint.getId()).append("_*"); + key.append("state_").append(monitorPointId).append("_*"); List<Map> stateList = redisUtils.getList(key.toString(),Map.class); int state = -1; if(stateList!=null){ @@ -50,7 +58,7 @@ } } state = state==-1?4:state; - monitorPoint.setState(state); + return state; } @Override public PageBean queryByPageBean(PageBean pageBean) { @@ -82,13 +90,42 @@ monitorPointMapper.insertSelective(monitorPoint); }else{ monitorPointMapper.updateByPrimaryKeySelective(monitorPoint); + // ������������������������������ ���redis��������������� + refreshDevicesInRedis(monitorPoint.getId()); } } catch (Exception ex){ throw ex; } } + /* + ������������������������������ ���redis��������������� + */ + private void refreshDevicesInRedis(int monitorPointId){ + Device device = new Device(); + device.setMonitorPointId(monitorPointId); + List<Device> deviceList = deviceMapper.select(device); + if (!CollectionUtils.isEmpty(deviceList)){ + List<Integer> orgIds = monitorPointMapper.selectOrganizationIds(monitorPointId); + if (!CollectionUtils.isEmpty(orgIds)){ + deviceList.stream().forEach(dev ->{ + if(!StringUtils.isNullOrEmpty(dev.getMac())){ + String key = "device_"+dev.getMac(); + // ��������������������� ������������redis + Device simpleDevice = new Device(); + simpleDevice.setId(dev.getId()); + simpleDevice.setDeviceVersion(dev.getDeviceVersion()); + simpleDevice.setMac(dev.getMac()); + simpleDevice.setMonitorPointId(dev.getMonitorPointId()); + // ������������������������������������������������������������������ + simpleDevice.setOrganizationIds(orgIds); + redisUtils.set(key,simpleDevice); + } + }); + } + } + } @Override public void deleteByIds(Integer... ids) { MonitorPoint monitorPoint = new MonitorPoint(); @@ -117,4 +154,31 @@ List<MonitorPoint> monitorPoints = monitorPointMapper.selectByExample(example); return monitorPoints; } + + /** + * + * @param idList + * @return {id:,state:} + */ + @Override + public List<Map<String, String>> queryMonitroPointsState(List<Integer> idList) { + List<Map<String, String>> list = idList.stream().map( id -> { + Integer state = getStateFromRedis(id); + Map<String,String> stateMap = new HashMap<>(); + stateMap.put("id",id.toString()); + stateMap.put("state",state.toString()); + return stateMap; + }).collect(Collectors.toList()); + return list; + } + + @Override + public List<MonitorPoint> getMonitorPointsByOrganizationId(Integer orgId) { + MonitorPoint monitorPoint = new MonitorPoint(); + monitorPoint.setIsDelete(Constants.IS_DELETE_FALSE); + if (Constants.isNotSpecialOrgId(orgId)) { + monitorPoint.setOrganizationId(orgId); + } + return monitorPointMapper.select(monitorPoint); + } } -- Gitblit v1.8.0