百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

历史数据库的设计与实现

liuian 2025-05-15 19:07 44 浏览

摘 要: 针对Wonderware平台自带的历史数据服务无法满足大量历史数据同时存储的问题,对该平台的历史数据服务进行了研究和分析,在保证Wonderware平台存储历史数据的正确性、及时性和完整性的前提下,结合Wonderware平台与.NET能够兼容的特性,设计了一种新的历史数据存储方法,使用C#语言完成了基于.NET的自定义历史数据库的开发并投入实际使用,运行效果良好。

0 引言

美国Wonderware公司创建于1987年4月,致力于开发基于IBM PC及其兼容计算机的、应用于工业及过程自动化领域的人机界面(HMI)软件,是一家领先的工业自动化与信息软件解决方案供应商[1]。Wonderware平台是美国Wonderware公司为适应严格的实时工业环境而开发的产品,其提供了一个工业化的应用服务、一个强大的历史数据库服务、一个易于使用的信息服务、以及无与伦比的连通性[2]。但是在实际使用过程中发现,当历史数据的数据量多到一定程度时,该平台自带的历史数据库服务无法满足同时存储这些数据的要求,历史服务器的日志中会出现告警和错误。针对该问题,本文深入研究了Wonderware平台收集历史数据的体系结构,摒弃了平台自带的历史数据库服务,并在此基础上研发了一种新的历史数据库,保证了在数据量巨大的情况下历史数据仍然能够正常进行存储。

1 历史数据存储体系结构

1.1 Wonderware平台配置历史数据库服务

在Wonderware平台的IDE中可以实现对整个平台服务的配置,在Platfrom级别和Engine级别的对象下包含历史数据服务的配置[3]。如图1所示,选中“Enable Storage To Historian”后,就开启了历史数据服务功能,经过正确配置后就可将该引擎下所有的历史数据存入历史服务器。

通过图1中的几个关键配置项,可以实现历史数据的存储。其中Historian用来配置历史数据服务器名称,Storeforward deletion threshold用来配置存储转发数据块的删除临界值,Storeforward minimum duration用来配置存储转发最小间隔,Forwarding chunk size用来配置转发数据块大小。通过这些配置可以发现,Wonderware自带历史数据服务的关键是通过存储转发完成历史数据的存储,即通过简洁的界面配置就可在系统各平台内进行历史数据存储。但是,在实际运行中发现,当Wonderware平台接入的数据点非常多时,历史数据服务存在低概率出现错误的可能性,会影响系统的正常使用。

1.2 自定义历史数据库的数据存储结构

数据库连接是一种关键的、有限的昂贵资源,建立一个数据库连接需要消耗大量系统资源,频繁地创建数据库连接会大大削弱应用性能,所以在自定义的历史数据库中,如何尽可能减少数据库的连接是关键所在。通过研究Wonderware平台自带的历史数据服务可以发现,历史数据通过存储转发策略进行存库。同样,在自定义历史数据库中也采用这种存储转发的策略,使用ADO.NET技术,将系统接收的数据连续存入中转文件[4],然后再将中转文件内容复制到历史数据库,每一个中转文件一旦被成功读取并将数据存储到数据库后就被删除,这样就在极大程度上节省了宝贵的数据库资源,降低了系统负载,杜绝历史数据存库的失败。本文中,在遥测对象中增加脚本程序,使用接口函数接收数据,对数据进行周期性和突发性地存储,然后将数据存入本地文件。在引擎中增加脚本程序,使用接口函数获取本地文件,将本地文件周期性存入历史数据库,然后删除已经被读取过的文件。流程如图2。

2 自定义历史数据库的设计

Wonderware平台以开发工具包的形式扩展了Microsoft Visual Studio.NET,并且在脚本中支持绝大部分 .NET函数。但是由于在脚本中进行代码编辑不方便,并且有些函数和类库使用起来不如在.NET中简单,所以此处采用编写外部函数库的方法,使用C#语言完成自定义函数库的开发。数据库平台选用SQL Server。

2.1 将历史数据存入中转文件

历史数据分为周期性存储和突发性存储,定义周期性存储间隔为5 s,当历史数据发生突变并且变化范围超过阈值时,进行突发性存储。在每一个对象的Function Script中获取数据后,将数据用“,”分隔,拼接成string类型的字符串,先放在动态数组里。动态数组是C#提供的一种优秀的数据结构,可以动态地分配存储空间,而不是像普通数组那样必须先定义好数组长度,所以使用List可以有效节省内存。

代码如下:

string combinedata=time+“,”+name+“,”+value+“,”+quality;

public static List<string> Liststr=new List<string>;

Liststr.Add(combinedata);

中转文件可以采用多种格式,此处采用TXT文件,按照存储周期为1 min将数组存入TXT文件。TXT文件被特定的命名格式(如“站名-点名-时间精确到分”)存放在D盘的名为“Data”的文件夹下。代码如下:

string Path="D:\\中转文件\\Engine_"+EngineName+"_当前时间"+"("+DateTime.Now.ToString("yyyyMMdd_HHmm")+").txt";//时间精确到分钟

2.2 将中转文件数据存入数据库

如果是用readline方法来逐行读取TXT中的数据无疑是最容易被想到的办法,但是这样会大大降低数据存储速度,并且会持续性占用大量数据库连接资源。所以需要一种更加优化的方法来进行数据的存储。

利用ADO.NET中的Datatable技术和SqlBulkCopy类,将TXT文本文件中的数据存储到数据表中,然后将数据表中的数据复制到数据库中。虽然使用SqlBulkCopy类只能向SQL Server表写入数据,但数据源不限于SQL Server,可以使用任何数据源,只要数据可加载到DataTable实例或可使用IDataReader实例读取数据即可[5]。此方法可以大量节省数据库资源,是一种高效的处理方式。

创建DataTable实例:

DataTable dt=new DataTable;

dt.Columns.Add(new DataColumn("时间"));

dt.Columns.Add(new DataColumn("名称"));

dt.Columns.Add(new DataColumn("数据"));

dt.Columns.Add(new DataColumn("质量"));

SqlBulkCopy将DataTable复制到数据库中:

System.Data.SqlClient.SqlBulkCopy sbc=new

System.Data.SqlClient.SqlBulkCopy(SQL

ConnectionString);

{

sbc.BulkCopyTimeout=5000;

sbc.BatchSize=dt.Rows.Count;

sbc.DestinationTableName="中转文件";

sbc.WriteToServer(dt);

}

3 结束语

使用C#语言设计的基于.NET平台的历史数据库具有存储速度快、占用资源少、保证数据完整性的优点,与Wonderware自带的历史数据库服务相比具有更优良的海量数据存储性能。目前该数据库已经应用到远动监控系统中,运行效果良好。

参考文献

[1] Invensys Systems, Inc. Alarm toolkit guide[R]. UK: Invensys Systems, Inc, 2009.

[2] Invensys Systems, Inc. IT alarms and events[R]. UK: Inven sys Systems, Inc, 2009.

[3] Anon. Wonderware[EB/OL]. (2013-12-19)[2015-05-10]. http://www.baike.baidu.com.

[4] NAGEL C.Professional C#4 and .NET 4[M].李铭,译.北京:清华大学出版社,2010.

[5] 张奇,李律松,卫建伟,等.Visual C#数据库项目案例导航[M].北京:清华大学出版社,2005.

相关推荐

驱动网卡(怎么从新驱动网卡)
驱动网卡(怎么从新驱动网卡)

网卡一般是指为电脑主机提供有线无线网络功能的适配器。而网卡驱动指的就是电脑连接识别这些网卡型号的桥梁。网卡只有打上了网卡驱动才能正常使用。并不是说所有的网卡一插到电脑上面就能进行数据传输了,他都需要里面芯片组的驱动文件才能支持他进行数据传输...

2026-01-30 00:37 liuian

win10更新助手装系统(微软win10更新助手)

1、点击首页“系统升级”的按钮,给出弹框,告诉用户需要上传IMEI码才能使用升级服务。同时给出同意和取消按钮。华为手机助手2、点击同意,则进入到“系统升级”功能华为手机助手华为手机助手3、在检测界面,...

windows11专业版密钥最新(windows11专业版激活码永久)

 Windows11专业版的正版密钥,我们是对windows的激活所必备的工具。该密钥我们可以通过微软商城或者通过计算机的硬件供应商去购买获得。获得了windows11专业版的正版密钥后,我...

手机删过的软件恢复(手机删除过的软件怎么恢复)
手机删过的软件恢复(手机删除过的软件怎么恢复)

操作步骤:1、首先,我们需要先打开手机。然后在许多图标中找到带有[文件管理]文本的图标,然后单击“文件管理”进入页面。2、进入页面后,我们将在顶部看到一行文本:手机,最新信息,文档,视频,图片,音乐,收藏,最后是我们正在寻找的[更多],单击...

2026-01-29 23:55 liuian

一键ghost手动备份系统步骤(一键ghost 备份)

  步骤1、首先把装有一键GHOST装系统的U盘插在电脑上,然后打开电脑马上按F2或DEL键入BIOS界面,然后就选择BOOT打USDHDD模式选择好,然后按F10键保存,电脑就会马上重启。  步骤...

怎么创建局域网(怎么创建局域网打游戏)

  1、购买路由器一台。进入路由器把dhcp功能打开  2、购买一台交换机。从路由器lan端口拉出一条网线查到交换机的任意一个端口上。  3、两台以上电脑。从交换机任意端口拉出网线插到电脑上(电脑设置...

精灵驱动器官方下载(精灵驱动手机版下载)

是的。驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能。1、全新驱动精灵2012引擎,大幅提升硬件和驱动辨识能力...

一键还原系统步骤(一键还原系统有哪些)

1、首先需要下载安装一下Windows一键还原程序,在安装程序窗口中,点击“下一步”,弹出“用户许可协议”窗口,选择“我同意该许可协议的条款”,并点击“下一步”。  2、在弹出的“准备安装”窗口中,可...

电脑加速器哪个好(电脑加速器哪款好)

我认为pp加速器最好用,飞速土豆太懒,急速酷六根本不工作。pp加速器什么网页都加速,太任劳任怨了!以上是个人观点,具体性能请自己试。ps:我家电脑性能很好。迅游加速盒子是可以加速电脑的。因为有过之...

任何u盘都可以做启动盘吗(u盘必须做成启动盘才能装系统吗)

是的,需要注意,U盘的大小要在4G以上,最好是8G以上,因为启动盘里面需要装系统,内存小的话,不能用来安装系统。内存卡或者U盘或者移动硬盘都可以用来做启动盘安装系统。普通的U盘就可以,不过最好U盘...

u盘怎么恢复文件(u盘文件恢复的方法)

开360安全卫士,点击上面的“功能大全”。点击文件恢复然后点击“数据”下的“文件恢复”功能。选择驱动接着选择需要恢复的驱动,选择接入的U盘。点击开始扫描选好就点击中间的“开始扫描”,开始扫描U盘数据。...

系统虚拟内存太低怎么办(系统虚拟内存占用过高什么原因)

1.检查系统虚拟内存使用情况,如果发现有大量的空闲内存,可以尝试释放一些不必要的进程,以释放内存空间。2.如果系统虚拟内存使用率较高,可以尝试增加系统虚拟内存的大小,以便更多的应用程序可以使用更多...

剪贴板权限设置方法(剪贴板访问权限)
剪贴板权限设置方法(剪贴板访问权限)

1、首先打开iphone手机,触碰并按住单词或图像直到显示选择选项。2、其次,然后选取“拷贝”或“剪贴板”。3、勾选需要的“权限”,最后选择开启,即可完成苹果剪贴板权限设置。仅参考1.打开苹果手机设置按钮,点击【通用】。2.点击【键盘】,再...

2026-01-29 21:37 liuian

平板系统重装大师(平板重装win系统)

如果你的平板开不了机,但可以连接上电脑,那就能好办,楼主下载安装个平板刷机王到你的个人电脑上,然后连接你的平板,平板刷机王会自动识别你的平板,平板刷机王上有你平板的我刷机包,楼主点击下载一个,下载完成...

联想官网售后服务网点(联想官网售后服务热线)

联想3c服务中心是联想旗下的官方售后,是基于互联网O2O模式开发的全新服务平台。可以为终端用户提供多品牌手机、电脑以及其他3C类产品的维修、保养和保险服务。根据客户需求层次,联想服务针对个人及家庭客户...