From 346bf9fc793f188caca408532265f8f862a23ff4 Mon Sep 17 00:00:00 2001 From: swb <jpy123456> Date: Mon, 26 Aug 2024 10:28:34 +0800 Subject: [PATCH] fix:设备分页查询接口修复 --- screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java | 41 +++++++++++++++++++++++++++++------------ 1 files changed, 29 insertions(+), 12 deletions(-) diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java index 89e6b95..37132e2 100644 --- a/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java +++ b/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java @@ -4,6 +4,7 @@ import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; +import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.googlecode.aviator.AviatorEvaluator; import com.googlecode.aviator.Expression; @@ -22,7 +23,6 @@ import com.moral.constant.RedisConstants; import com.moral.util.ConvertUtils; import com.moral.util.DateUtils; - import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; @@ -36,6 +36,8 @@ import java.beans.PropertyDescriptor; import java.lang.reflect.Field; import java.lang.reflect.Method; +import java.lang.reflect.Type; +import java.text.SimpleDateFormat; import java.util.*; import java.util.stream.Collectors; @@ -189,7 +191,7 @@ //������������������redis setDeviceInfoToRedis(mac, deviceInfo); //������deviceInfo������ - CacheUtils.refreshDeviceAlarmInfo(); + CacheUtils.refreshDeviceAlarmInfo(mac); //������������������ HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest(); StringBuilder content = new StringBuilder(); @@ -289,6 +291,9 @@ queryWrapper.eq("monitor_point_id", mpId); } + //������������������������ + queryWrapper.eq("is_delete", Constants.NOT_DELETE); + //���������������mac������������ if (name != null && mac != null) { queryWrapper.like("name", name).or().like("mac", mac); @@ -304,7 +309,7 @@ } else { queryWrapper.orderByDesc("create_time"); } - queryWrapper.eq("is_delete", Constants.NOT_DELETE); + Page<Device> devicePage = new Page<>(page, size); deviceMapper.selectPage(devicePage, queryWrapper); List<Device> devices = devicePage.getRecords(); @@ -442,8 +447,9 @@ } @Override - public Map<String, Object> adjustDeviceData(Map<String, Object> deviceData) { - String mac = deviceData.remove("mac").toString(); + public Map<String, Object> adjustDeviceData(Map<String, Object> deviceData,String code) { +// String mac = deviceData.remove("mac").toString(); + String mac = deviceData.get("mac").toString(); //���redis������������������ Map<String, Object> adjustFormula = redisTemplate.opsForHash().entries(RedisConstants.ADJUST + "_" + mac); if (!ObjectUtils.isEmpty(adjustFormula)) { @@ -454,7 +460,7 @@ if (govMpInfo.get("guid") != null) { aqiMap = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, govMpInfo.get("guid").toString()); } - return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap); + return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap,code); } deviceData.remove("DataTime"); return deviceData; @@ -462,7 +468,8 @@ @Override public Map<String, Object> adjustSpecialDeviceData(Map<String, Object> deviceData) { - String mac = deviceData.remove("mac").toString(); +// String mac = deviceData.remove("mac").toString(); + String mac = deviceData.get("mac").toString(); //���redis������������������ Map<String, Object> adjustFormula = redisTemplate.opsForHash().entries(RedisConstants.ADJUST + "_" + mac); if (!ObjectUtils.isEmpty(adjustFormula)) { @@ -473,14 +480,13 @@ if (ObjectUtils.isEmpty(aqiMap)) { aqiMap = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, cityCode); } - return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap); + return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap,"0"); } deviceData.remove("DataTime"); return deviceData; } @Override - @Transactional public void judgeDeviceState(Map<String, Object> deviceData) { String mac = deviceData.remove("mac").toString(); Device device = (Device) redisTemplate.opsForHash().get(RedisConstants.DEVICE_INFO, mac); @@ -516,9 +522,10 @@ } } //������������������ - UpdateWrapper<Device> updateWrapper = new UpdateWrapper<>(); - updateWrapper.eq("id", device.getId()).set("state", String.valueOf(state)); - deviceMapper.update(null, updateWrapper); + Device device1 = new Device(); + device1.setId(device.getId()); + device1.setState(String.valueOf(state)); + deviceMapper.updateById(device1); } @Override @@ -620,4 +627,14 @@ organizationUnitAlarmMapper.update(null, deleteWrapper); } } + + @Override + public void setRedisDevice() { + List<Device> list = lambdaQuery().eq(Device::getIsDelete,0).list(); + for(Device d : list){ + redisTemplate.opsForHash().delete(RedisConstants.DEVICE, d.getMac()); + Map<String, Object> deviceInfo = selectDeviceInfoById(d.getId()); + setDeviceInfoToRedis(d.getMac(), deviceInfo); + } + } } -- Gitblit v1.8.0