From 6a1b28591ebe95ed9f26810fbf9677da5c87692d Mon Sep 17 00:00:00 2001 From: xufenglei <xufenglei> Date: Mon, 12 Mar 2018 09:24:36 +0800 Subject: [PATCH] 大屏 报表接口 --- src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java | 58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 54 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 e979b68..6e8c2c3 100644 --- a/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java +++ b/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java @@ -8,15 +8,22 @@ import javax.annotation.Resource; +import org.apache.commons.collections.CollectionUtils; +import org.springframework.stereotype.Service; + import com.github.pagehelper.PageHelper; import com.moral.common.bean.Constants; import com.moral.common.bean.PageBean; -import com.moral.common.util.*; -import org.springframework.stereotype.Service; - +import com.moral.common.util.ExampleUtil; +import com.moral.common.util.RedisUtils; +import com.moral.common.util.StringUtils; +import com.moral.common.util.ValidateUtil; +import com.moral.entity.Device; import com.moral.entity.MonitorPoint; +import com.moral.mapper.DeviceMapper; import com.moral.mapper.MonitorPointMapper; import com.moral.service.MonitorPointService; + import tk.mybatis.mapper.entity.Example; import tk.mybatis.mapper.entity.Example.Criteria; @@ -24,6 +31,8 @@ public class MonitorPointServiceImpl implements MonitorPointService { @Resource private MonitorPointMapper monitorPointMapper; + @Resource + private DeviceMapper deviceMapper; @Resource RedisUtils redisUtils; private static Class ENTITY_CLASS = MonitorPoint.class; @@ -84,15 +93,43 @@ monitorPoint.setIsDelete(Constants.IS_DELETE_FALSE); monitorPointMapper.insertSelective(monitorPoint); }else{ - // TODO ������������id������������������redis��������������� 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(); @@ -138,4 +175,17 @@ }).collect(Collectors.toList()); return list; } + + @Override + public List<MonitorPoint> getMonitorPointsByOrganizationId(Integer orgId) { + Example example = new Example(MonitorPoint.class); + Criteria criteria = example.createCriteria(); + + criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE); + if (Constants.isNotSpecialOrgId(orgId)) { + criteria.andEqualTo("organizationId", orgId); + } + example.orderBy("name").asc(); + return monitorPointMapper.selectByExample(example); + } } -- Gitblit v1.8.0