From d384786ab5868cd4d856691372eee5359e7d9b2c Mon Sep 17 00:00:00 2001
From: zxl <763096477@qq.com>
Date: 星期五, 28 三月 2025 17:48:47 +0800
Subject: [PATCH] 导出新增 连个列,以及同步数据库时点位名修改未成功问题

---
 ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java |   65 ++++++++++++++++++++++++++++++++
 1 files changed, 64 insertions(+), 1 deletions(-)

diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
index 8f380c1..e16d539 100644
--- a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
+++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
@@ -35,6 +35,7 @@
 import com.ycl.utils.http.HttpUtils;
 import com.ycl.utils.redis.RedisCache;
 import com.ycl.utils.uuid.IdUtils;
+import constant.ApiConstants;
 import constant.Constants;
 import constant.RedisConstant;
 import enumeration.ErrorType;
@@ -79,6 +80,7 @@
 public class WorkOrderServiceImpl extends ServiceImpl<WorkOrderMapper, WorkOrder> implements WorkOrderService {
 
     private final YwPointService ywPointService;
+    private final YwPointMapper ywPointMapper;
     private final TMonitorMapper monitorMapper;
     private final DynamicColumnMapper dynamicColumnMapper;
     private final WorkOrderAuditingRecordMapper workOrderAuditingRecordMapper;
@@ -470,10 +472,25 @@
                 UrgentLevelEnum.WARNING,
                 workOrder.getWorkOrderNo());
         notifyService.save(notify);
+        List<WorkOrderVO> workOrderVOS = workOrderErrorTypeMapper.getErrorListByNumbers(Arrays.asList(workOrder.getWorkOrderNo()));
+
         // 鍚屾鐐逛綅鐘舵��
         if (form.getAuditingResult() == WorkOrderStatusEnum.AUDITING_SUCCESS) {
             ywPointService.updateRecovery(Collections.singletonList(workOrder.getSerialNumber()), 0);
+            //濡傛灉宸ュ崟涓虹绾垮伐鍗曢偅涔堜慨鏀圭偣浣峱ingOnline涓哄湪绾�
+            if (!CollectionUtils.isEmpty(workOrderVOS)) {
+                List<String> ips = new ArrayList<>();
+                for (WorkOrderVO workOrderVO : workOrderVOS) {
+                    if(ErrorType.DEVICE_OFFLINE.getValue().equals(workOrderVO.getErrorType())){
+                        ips.add(workOrderVO.getIp());
+                    }
+                }
+                if(!CollectionUtils.isEmpty(ips)) {
+                    monitorMapper.batchUpdateOnline(ips, new Date(), ApiConstants.UY_OnlineSite_Online);
+                }
+            }
         }
+
         return Result.ok("鎿嶄綔鎴愬姛");
     }
 
@@ -513,11 +530,30 @@
                     workOrder.getWorkOrderNo());
             notifies.add(notify);
         }
+        notifyService.saveBatch(notifies);
         // 鍚屾鐐逛綅鐘舵��
         if (form.getAuditingResult() == WorkOrderStatusEnum.AUDITING_SUCCESS) {
             ywPointService.updateRecovery(serialNumbers, 0);
+            //绛涢�夊嚭绂荤嚎宸ュ崟ip骞朵慨鏀瑰湪绾跨姸鎬�
+            if (!CollectionUtils.isEmpty(serialNumbers)) {
+                Map<String, List<String>> errorTypes = workOrderErrorTypeMapper.getErrorListByNumbers(workOrderNoList).stream().collect(Collectors.groupingBy(
+                        WorkOrderVO::getIp,
+                        Collectors.mapping(
+                                WorkOrderVO::getErrorType,
+                                Collectors.toList()
+                        )
+                ));
+                List<String> ips = new ArrayList<>();
+                errorTypes.forEach((key, value) -> {
+                    if (!CollectionUtils.isEmpty(value) && value.contains(ErrorType.DEVICE_OFFLINE.getValue())) {
+                        ips.add(key);
+                    }
+                });
+                if(!CollectionUtils.isEmpty(ips)) {
+                    monitorMapper.batchUpdateOnline(ips, new Date(), ApiConstants.UY_OnlineSite_Online);
+                }
+            }
         }
-        notifyService.saveBatch(notifies);
         return Result.ok("鎿嶄綔鎴愬姛");
     }
 
@@ -1130,6 +1166,9 @@
         return Result.ok().data(workOrder);
     }
 
+    @Autowired
+    private WorkOrderMapper workOrderMapper;
+
     /**
      * 宸ュ崟瀵煎嚭鐨勯�昏緫
      * 鏍囩锛氬悓涓�涓猧p鏍囩鍚堝湪涓�璧凤紝閽堝绂荤嚎宸ュ崟锛坕p鐩稿悓灏变笉浼氱敓鎴愬伐鍗曪級锛屾柟渚胯繍缁村鐞�
@@ -1159,6 +1198,30 @@
             query.setErrorTypeList(errorTypeList);
         }
         List<WorkOrderVO> export = baseMapper.export(query);
+
+
+        List<String> workOrderNos = export.stream().map(WorkOrderVO::getWorkOrderNo).collect(Collectors.toList());
+        List<WorkOrderVO> auditTimeList = workOrderMapper.getAuditTimeList(workOrderNos);
+        Map<String, List<Date>> auditTimeMap = auditTimeList.stream()
+                .collect(Collectors.groupingBy(
+                        WorkOrderVO::getWorkOrderNo, // 鍒嗙粍鐨勯敭
+                        Collectors.mapping(WorkOrderVO::getAuditTime, Collectors.toList())));
+        if (!CollectionUtils.isEmpty(workOrderNos)){
+           export.forEach(workOrderVO -> {
+               List<Date> auditTimes = auditTimeMap.get(workOrderVO.getWorkOrderNo());
+               if (!CollectionUtils.isEmpty(auditTimes)){
+                   //瀹℃牳閫氳繃鏃堕棿
+                   Date passTime = Collections.max(auditTimes);
+                   ZoneId zoneId = ZoneId.systemDefault();
+                   workOrderVO.setPassTime(passTime.toInstant().atZone(zoneId).toLocalDateTime());
+               }
+           });
+        }
+
+
+
+
+
         if (CollectionUtils.isEmpty(export)) return new ArrayList<WorkOrderVO>();
         List<String> ips = export.stream().map(WorkOrderVO::getIp).collect(Collectors.toList());
         //鏌ュ嚭鐩稿悓ip鐨勮澶囥�佸苟鏌ュ嚭鏍囩

--
Gitblit v1.8.0