紫金桥跨平台软件报警排名功能实现

2023-11-22 19:10

本文主要是介绍紫金桥跨平台软件报警排名功能实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现方法

 利用紫金桥内置SQL功能查询指定时间段内的报警并按报警内容分组统计次数,然后再针对结果进行排序输出到表格显示。因为紫金桥是实时数据库而非关系库,内置SQL功能只是为了方便用户查询数据而开发出的转译查询功能,所以只支持简单查询。所以像 “ group by xx order byxx” 就不支持了,要不然一条sql查询即可完成报警统计排序功能了。

实现脚本

 ①初始化表格,sql查询历史报警

ObSql rsql;
ObTable tab;table.RemoveRows(1,table.RowCount());//表格保留一行
table.ClearContent();//表格初始化,表格保留一行rsql.Connect("Local");
rsql.Query("SELECT Desc,Count(Name) as cnt from hisalarmdata where DateTime>="+ToString(CurTime-3600*8)+" and DateTime<="+ToString(CurTime)+" and ACK=0 group by Desc ",tab);//查询最近8小时内报警统计次数
rsql.close();
  • sql查询返回的tab内容
    在这里插入图片描述
    ②对tab内容按次数进行排序
  • 排序的实现
      我能想到好的排序方法是利用数组实现,如果朋友们有更好的实现方式可以私聊告知我一下,到时我再补充到文章中。数组排序有两种,一种是文本型数组按字符串排序,一种是数值型数组按数值排序,两种均可。这里以文本数组排序方式来演示。
      tab表里有2个字段数据,一个是报警内容,一个是报警次数 ,我们要按文本排序,首先就要将两个字段的数据合并成一个字符串,因为要按次数排序,所以次数要放到首位(左边),其次为报警内容。因为排序后,为了快速从字符串里还原出次数和内容,所以两个数据间加一个特殊符号来分隔( 注意:报警内容里不能含有分隔符号 ),演示脚本以“ ”来分隔。所以形成文本格式为报警次数 ”来分隔。所以形成文本格式为 报警次数 来分隔。所以形成文本格式为报警次数报警内容 如:3$液位超限_Err3
int i,cnt=tab.GetRowCount();//获得tab里记录数if cnt<=0 then  //没有报警返回不继续执行return 0;
endifstring desc,almcnt,sbuff[];for i=0 to cnt-1desc=tab.Get(i,0);almcnt=tab.Get(i,1);sbuff.add(almcnt+"$"+desc);//拼接文本添加至数组
nextErrorLog("sbuff排序前.log",sbuff);//将数组内容输出到文件sbuff.sort(0);//降序ErrorLog("sbuff排序后.log",sbuff);

tab原始内容 :
在这里插入图片描述

拼接添加倒sbuff,排序前:
在这里插入图片描述

排序后:
在这里插入图片描述

  • 数组数据还原到表格里
     通过一个循环依次取出数组里的数据,然后将数据还原赋值到表格即可。
table.AddRows(cnt-1,1);//根据记录数添加表格行数
string arr[];
//数组遍历
for i=0 to cntarr=StrSplit(sbuff[i],"$");//通过分隔符取出报警次数和内容 放到一个数组里table.SetCell(i,0,arr[1]);//向表格单元格 添加报警内容table.SetCell(i,1,arr[0]);//向表格单元格 添加报警数量
next

执行结果:
在这里插入图片描述

完善问题

 细心朋友们会发现上面的排序还是会存在一点bug的,如果数值部分位数不一样会出现排序错误。如【1,12,111,5,33,88,7】降序排序后则为【88,7,5,33,12,111,1】,可以看到顺序明显错误,这是因为文本排序是按字符逐字排序的,所以我们要统一长度,长度不满足的用符号补足即可解决问题。因为是数值,可以按下面方式处理:

在这里插入图片描述
完整脚本:

ObSql rsql;
ObTable tab;
table.RemoveRows(1,table.RowCount());//表格保留一行
table.ClearContent();//表格初始化,表格保留一行rsql.Connect("Local");
rsql.Query("SELECT Desc,Count(Name) as cnt from hisalarmdata where DateTime>="+ToString(CurTime-3600*8)+" and DateTime<="+ToString(CurTime)+" and ACK=0 group by Desc ",tab);//查询最近8小时内报警统计次数
rsql.close();int i,cnt=tab.GetRowCount();//获得tab里记录数if cnt<=0 then  //没有报警返回不继续执行return 0;
endifstring desc,almcnt,sbuff[];for i=0 to cnt-1desc=tab.Get(i,0);almcnt= ToString(1000000+tab.Get(i,1));sbuff.add(almcnt+"$"+desc);//拼接文本添加至数组
next
sbuff.sort(0);//降序
table.AddRows(cnt-1,1);//根据记录数添加表格行数
string arr[];
//数组遍历
for i=0 to cntarr=StrSplit(sbuff[i],"$");//通过分隔符取出报警次数和内容 放到一个数组里table.SetCell(i,0,arr[1]);//向表格单元格 添加报警内容table.SetCell(i,1,StrToInt(arr[0])-1000000);//向表格单元格 添加报警数量
next

如果您有更好的方法,欢迎私聊。

更多技术文章,请访问紫金桥知识库:紫金桥知识库
在这里插入图片描述

这篇关于紫金桥跨平台软件报警排名功能实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/412280

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4