From 2633facbfec13267389edde5c29d6e66645c2356 Mon Sep 17 00:00:00 2001
From: Darker <mr.darker@163.com>
Date: 星期四, 27 二月 2025 18:29:13 +0800
Subject: [PATCH] 1. 报警管理类添加两个表,并且修改了字段,完善修改后的函数

---
 SourceCode/Bond/Servo/AlarmManager.h |   97 +++++++++++++++++++++++++++++++++++-------------
 1 files changed, 71 insertions(+), 26 deletions(-)

diff --git a/SourceCode/Bond/Servo/AlarmManager.h b/SourceCode/Bond/Servo/AlarmManager.h
index 71cac72..523ca3f 100644
--- a/SourceCode/Bond/Servo/AlarmManager.h
+++ b/SourceCode/Bond/Servo/AlarmManager.h
@@ -17,6 +17,18 @@
     std::string strDescription;
 };
 
+struct AlarmData {
+    int nId;                       // 错误码
+    int nSeverityLevel;            // 报警等级
+    int nDeviceId;                 // 设备ID
+    int nUnitId;                   // 单元ID
+    std::string strDeviceName;     // 设备名称
+    std::string strUnitName;       // 单元名称
+    std::string strDescription;    // 描述
+    std::string strStartTime;      // 开始时间
+    std::string strEndTime;        // 结束时间
+};
+
 using AlarmMap = std::unordered_map<int, AlarmInfo>;
 
 class AlarmManager {
@@ -51,77 +63,80 @@
     bool destroyAlarmTable();
 
     /**
+    * 插入模拟数据
+    */
+    void insertMockData();
+
+    /**
      * 添加报警
-     * @param id 报警ID
-	 * @param deviceName 设备名称
-     * @param description 报警描述
-     * @param startTime 报警开始时间
-     * @param endTime 报警结束时间
+     * @param alarmData 报警数据的结构体
      * @return 成功返回true,失败返回false
      */
-    bool addAlarm(const std::string& id, const std::string& deviceName, const std::string& description, const std::string& startTime, const std::string& endTime);
+    bool addAlarm(const AlarmData& alarmData);
 
     /**
      * 查询所有报警数据
-     * @return 包含所有报警数据的二维字符串向量
+     * @return 包含所有报警数据的结构体
      */
-    std::vector<std::vector<std::string>> getAllAlarms();
+    std::vector<AlarmData> getAllAlarms();
 
     /**
      * 根据报警ID查询报警
      * @param id 报警ID
-     * @return 包含筛选后报警数据的二维字符串向量
+     * @return 包含筛选后报警数据的结构体
      */
-    std::vector<std::vector<std::string>> getAlarmsById(const std::string& id);
+    std::vector<AlarmData> getAlarmsById(const std::string& id);
 
     /**
      * 根据描述查询报警
      * @param description 报警描述的筛选条件
-     * @return 包含筛选后报警数据的二维字符串向量
+     * @return 包含筛选后报警数据的结构体
      */
-    std::vector<std::vector<std::string>> getAlarmsByDescription(const std::string& description);
+    std::vector<AlarmData> getAlarmsByDescription(const std::string& description);
 
     /**
      * 根据时间范围查询报警
      * @param startTime 起始时间
      * @param endTime 结束时间
-     * @return 包含查询结果的二维字符串向量
+     * @return 包含查询结果的报警数据
      */
-    std::vector<std::vector<std::string>> getAlarmsByTimeRange(
-        const std::string& startTime, const std::string& endTime);
+    std::vector<AlarmData> getAlarmsByTimeRange(const std::string& startTime, const std::string& endTime);
 
 	/**
 	* 根据ID和时间范围查询报警
 	 * @param id 报警ID
 	 * @param startTime 起始时间
 	 * @param endTime 结束时间
-	 * @return 包含查询结果的二维字符串向量
+	 * @return 包含查询结果的报警数据
 	 */
-    std::vector<std::vector<std::string>> getAlarmsByIdAndTimeRange(
-        const std::string& id, const std::string& startTime, const std::string& endTime);
+    std::vector<AlarmData> getAlarmsByIdAndTimeRange(const std::string& id, const std::string& startTime, const std::string& endTime);
 
     /**
      * 获取报警数据
      * @param startPosition 起始位置
      * @param count 获取的记录数量
-     * @return 包含报警数据的二维字符串向量
+     * @return 包含查询结果的报警数据
      */
-    std::vector<std::vector<std::string>> getAlarms(int startPosition, int count);
+    std::vector<AlarmData> getAlarms(int startPosition, int count);
 
     /**
      * 获取筛选后的报警数据
 	 * @param id 报警ID的筛选条件
+     * @param severityLevel 报警等级筛选条件
 	 * @param deviceName 设备名称的筛选条件
+     * @param unitName 单元名称的筛选条件
      * @param description 报警描述的筛选条件
      * @param startTime 起始时间筛选条件
      * @param endTime 结束时间筛选条件
      * @param pageNumber 页码
      * @param pageSize 每页的记录数
-     * @return 包含筛选后报警数据的二维字符串向量
+     * @return 包含查询结果的报警数据
      */
-    std::vector<std::vector<std::string>> getFilteredAlarms(
+    std::vector<AlarmData> getFilteredAlarms(
         const std::string& id,
+        const std::string& severityLevel,
         const std::string& deviceName,
+        const std::string& unitName,
         const std::string& description,
         const std::string& startTime,
         const std::string& endTime,
@@ -131,7 +146,9 @@
     /**
      * 获取符合条件的报警总数
      * @param id 报警ID的筛选条件
-	 * @param deviceName 设备名称的筛选条件
+     * @param severityLevel 报警等级筛选条件
+     * @param deviceName 设备名称的筛选条件
+     * @param unitName 单元名称的筛选条件
      * @param description 报警描述的筛选条件
      * @param startTime 起始时间筛选条件
      * @param endTime 结束时间筛选条件
@@ -139,7 +156,9 @@
      */
     int getTotalAlarmCount(
         const std::string& id,
+        const std::string& severityLevel,
         const std::string& deviceName,
+        const std::string& unitName,
         const std::string& description,
         const std::string& startTime,
         const std::string& endTime);
@@ -147,19 +166,45 @@
 	/**
 	 * 更新报警结束时间
 	 * @param id 报警ID
+     * @param severityLevel 报警等级筛选条件
+     * @param deviceId 设备ID
+     * @param unitId 单元ID
 	 * @param description 报警描述
 	 * @param startTime 报警开始时间
 	 * @param newEndTime 新的报警结束时间
 	 * @return 成功返回true,失败返回false
 	 */
-    bool updateAlarmEndTime(const std::string& id, const std::string& deviceName, const std::string& description, const std::string& startTime, const std::string& newEndTime);
+    bool updateAlarmEndTime(
+        const std::string& id,
+        const std::string& severityLevel,
+        const std::string& deviceId,
+        const std::string& unitId,
+        const std::string& description,
+        const std::string& startTime,
+        const std::string& newEndTime);
 
     /**
      * 清理旧报警
      * @param daysToKeep 保留的天数
-	 * @param deviceName 设备名称
+	 * @param deviceId 设备ID
+     * @param unitId 单元ID
      */
-    void cleanOldAlarms(int daysToKeep = 30, const std::string& deviceName = "");
+    void cleanOldAlarms(int daysToKeep = 30, const std::string& deviceId = "", const std::string& unitId = "");
+
+    /**
+    * 通过设备ID获取设备名称
+    * @param deviceId 设备ID
+    * @return 成功返回设备名称,失败返回空
+    */
+    std::string getDeviceNameById(int deviceId);
+
+    /**
+    * 通过设备ID和单元ID获取单元名称
+    * @param deviceId 设备ID
+    * @param unitId 单元ID
+    * @return 成功返回单元名称,失败返回空
+    */
+    std::string getUnitNameById(int deviceId, int unitId);
 
 	/**
 	 * 读取报警文件

--
Gitblit v1.9.3