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