杰控FameView在数据库连接和查询方面的应用

供稿:北京杰控科技有限公司

  • 关键词:工控,组态软件,接触器,编程软件
  • 作者:北京杰控科技有限公司

在自动化生产过程中,监控软件的使用已经很普遍,但在国内的大多数系统仅限于简单的数据监视和修改,更应该利用系统自动产生统计数据和过程数据,为企业提供管理数据,为生产提供经验数据。

FameView提供了完整的数据库方案来完成以上功能,并在首钢、邯钢、燕化等企业进行了成功应用。

首先要把FameView从现场设备中的数据存储进行前期处理,把有效的数据存储到到数据库,FameView可通过三种方法实现:
(1)使用数据库连接功能,FameView在长期的实践过程中,开发了具有功能丰富、性能稳定、简单易用的功能模块,被称为“数据库连接”,具有以下功能:
非常简单实用,只需点击几下按钮,填写一个表格即可实现;
通过多线程的方式,能同时与32个数据表进行连接;
通过ADO数据库编程方法实现,精度能达到100毫秒;
能够支持SQL Server、Oracle、Access等数据库;
数据表的格式由用户自行定义;
能通过时间、变量事件、人工事件来触发与数据库之间的连接;
与数据库的连接方式有数据追加、数据修改、数据读取、调用存储过程四种方法;
调用存储过程的实现,受到MES/ERP系统的欢迎,可能是目前最好的数据提交方法;
能对实时过程数据进行前期处理,避免在数据服务器中产生垃圾数据,或增加数据服务器的负担;提供的前期处理方式有当前值、累加值、平均值、增加值、减少值、差值等20多种。
如果是比较复杂的前期处理方式,可以通过提供的VBScript脚本自行编写;

(2)使用VBScript脚本调用系统提供的ADO功能;如果您是熟悉软件编程的工程师,可能更希望通过自行编写程序,来实现与数据库的数据交换;FameView不会使您失望,提供了以下方法供使用:
UserDB.SetConnectMode、UserDB.SetConnectTimeout、UserDB.OpenConnect、UserDB.CloseConnect、UserDB.SetFilter、UserDB.SetOrderby、UserDB.OpenRecordset、UserDB.CloseRecordset、UserDB.AddNew、UserDB.Delete、UserDB.Update、UserDB.MoveFirst、UserDB.MoveLast、UserDB.MoveNext、UserDB.MovePrevious、UserDB.Move、UserDB.IsEOF()、UserDB.IsBOF()、UserDB.IsEmpty、UserDB.SetFieldValue、UserDB.GetFieldValue、

(3) 使用VBScript脚本调用数据存储过程功能;如果您希望使用更高级、更高效的数据库交互方法,您可以尝试使用此方法,FameView提供了以下方法供使用:
StoredProc.OpenConnect、StoredProc.CloseConnect、StoredProc.SetCommandText、StoredProc.SetInputParamCount、StoredProc.SetInputParam、StoredProc.SetOutputParamCount、StoredProc.SetOutputParam、StoredProc.Execute、StoredProc.GetOutputValue、

数据经处理进入了数据,并没有万事大吉,对于95%的中小型系统,或还没有上MES/ERP的企业,只相当于万里长征的第一步,如果数据不能被查看、统计和分析,数据库中的数据只能是垃圾,难免被清除的命运;幸好FameView提供了变废为宝的产品-fmDBWeb,能为现有系统组态出一个小型网站,从而发布数据,提供的功能如下:
处理的数据库对象为历史数据库、报警数据库、用户数据库、实时数据库、事件信息数据库;
通过组态的方式对分布在企业或自动化系统中的各种数据库进行需求分析,生成XML格式的数据表信息文件;
根据业务范围组态出1-99个级别,级别不同能够访问的数据内容不同;
根据实际需要组态出1-99个用户,每个用户能拥有多个级别;
根据以上的组态结果,编译并生成Web网站;
当某用户登陆网站系统后,便能以表格、曲线、报表的方式查看相应的统计数据,还可以下载数据到本地;

经过以上方案,扩展了监控软件的功能,实现了数据的统计、存储、查看、分析功能,能满足大多数中小型企业和系统的需求,运行稳定,简单易用,实施工期非常短,已深受用户的好评。

发布时间:2006年2月27日 11:23  人气:   审核编辑(邝红亮)
更多内容请访问(北京杰控科技有限公司
相关链接

我有需求