From 371a381267699280f45748c13ed42faba66b6577 Mon Sep 17 00:00:00 2001 From: jinpengyong <jpy123456> Date: Thu, 15 Jul 2021 17:34:32 +0800 Subject: [PATCH] update redis key --- screen-job/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java | 12 +++++------- 1 files changed, 5 insertions(+), 7 deletions(-) diff --git a/screen-job/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java b/screen-job/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java index 8850e00..eae61a6 100644 --- a/screen-job/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java +++ b/screen-job/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java @@ -13,6 +13,7 @@ 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 java.util.Date; import java.util.List; @@ -42,12 +43,12 @@ //������������������������ List<Device> devices = deviceMapper.selectList(queryWrapper); for (Device device : devices) { - Map<String, Object> data = getDataFromRedis(device.getMac()); + Map<String, Object> data = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.DATA_SECOND, device.getMac()); device.setState(Constants.DEVICE_STATE_OFFLINE); if (data != null && data.containsKey("DataTime")) { - long time = Long.parseLong(data.get("DataTime").toString()); + Date time = DateUtils.getDate((String) data.get("DataTime"), DateUtils.yyyyMMddHHmmss_EN); //��������������������������������� - if (DateUtils.getDateOfMin(new Date(time), 2).getTime() < new Date().getTime()) { + if (DateUtils.getDateOfMin(time, 2).getTime() < new Date().getTime()) { updateDeviceState(device); } } else { @@ -57,13 +58,10 @@ } @Override + @Transactional public void updateDeviceState(Device device) { UpdateWrapper<Device> updateWrapper = new UpdateWrapper<>(); updateWrapper.eq("id", device.getId()).set("state", device.getState()); deviceMapper.update(null, updateWrapper); - } - - private Map<String, Object> getDataFromRedis(String mac) { - return (Map<String, Object>) redisTemplate.opsForValue().get(RedisConstants.DEVICE_DATA + mac); } } -- Gitblit v1.8.0