浅谈基于WINCC工控组态软件的关系数据库

出处:赵秀梅 发布于:2011-08-23 12:13:00

  SIMATIC WinCC是个使用的32位技术的过程监视系统,具有良好的开放性和灵活性。从面市伊始,用户就对SIMATIC WinCC印象深刻。一方面,是其高水平的创新,它使用户在早期就认识到即将到来的发展趋势并予以实现;另一方面,是其基于标准的长期产品策略,可确保用户的投资利益。凭籍这种战略思想,WinCC,这一运行于Microsoft Windows 2000和XP下的Windows控制中心,已发展成为欧洲市场中的,乃至业界遵循的标准。如果你想使设备和机器化运行,如果你想地提高工厂的可用性和生产效率,WinCC当是上乘之选。

  WINCC的数据有设计时数据库和运行时数据库,分别放在相关的目录。设计时数据库没有研究的必要性,但运行时数据库要知道它的名称,其名称一般是“CC_工程名_年_月_日_时_分_秒R”,无论准备以DSN或OLEDB的方式访问数据库,都需要该名称。将WINCC激活,然后在“ODBC管理器”或“SQL企业管理器”下的“DATABASE”可以看到运行时数据库的名称。其实,WINCC在运行时,根据WINCC的设置,数据归档以一定时间做为基准,形成数据片段。在数据片段下,有3个表是用户所关心的:ARCHIVE、TAGPRESSED和MSARCLONG。

1 总体思路

  WINCC项目中通用C和VB 两种语言,所以,采用与数据库进行通信的必要条件就是熟悉这2种语言。作为编程语言来说,编程只是实现结果的方式,重点在于通信方式的建立。下面分别从数据通信方式和实现方法来介绍。

2 数据通信方式

  与数据库通信的数据访问接口有以下几种[2]。

  (1)数据连接器:提供绑定ADO数据源到窗体的数据绑定控件上。ADC主要是一种直接访问或者通过ADO访问远程OLEDB对象的技术,它支持主要应用在微软IE浏览器上的数据绑定控件,是特地为以Web上的浏览器为基础的应用程序而设计的。

  (2)Active数据对象:ADO实际是一种提供访问各种数据类型的连接机制。ADO设计为一种极简单的格式,通过ODBC的方法同数据库接口。可以使用任何一种ODBC数据源,既适合于SQL Server、Oracle、Access等数据库应用程序,也适合于Excel表格、文本文件、图形文件和无格式的数据文件。ADO是基于OLEDB之上的技术,因此ADO通过其内部的属性和方法提供统一的数据访问接口方法。

  (3)数据访问对象:一种面向对象的界面接口。通过DAO/JET功能可以访问ISAM数据库,使用DAO/ODBCDirect功能可以实现远程RDO功能。使用DAO的程序编码非常简单,DAO提供丰富的游标类型的结果集和非游标类型的结果集,同DDL的功能类似。DAO模型是设计关系数据库系统结构的对象类的集合,它提供了完成管理这样一个系统所需的全部操作的属性和方法,包括创建数据库,定义表、字段和索引,建立表间的关系,定位和查询数据库等工具。

  (4)数据连接性引擎技术JET:一种基于工作站通过DAO的数据库访问机制。虽然可以通过微软Access提供的ODBC驱动程序访问JET数据库,但使用这些驱动程序在功能上有所限制。

  (5)开放式的数据库连接:一种公认的关系数据源的接口界面。它快而轻,并且提供统一接口的界面。ODBC对任何数据源都未作优化。

  (6)ODBCDirect:一种基于DAO对象的新的DAO模式,其方法和属性与RDO功能相同。在有DAO代码存在的场合使用,可用来访问远程数据源。

  (7)OLEDB:一种底层数据访问界面接口,是用于第三方驱动程序商家开发输出数据源到ADO技术的应用程序,或用于C++的开发者开发定制的数据库组件。OLEDB不能被VB直接调用。

  (8)远程数据访问控件RDC:一种对RDO数据绑定的控件。可以将特定的结果集输出到数据源控件。

  (9)远程数据对象:远程数据对象和集合为使用代码来创建和操作一个远程ODBC数据库系统的各个部件提供了一个框架。对象和集合都具有描述数据库的各个部件特征的属性以及用来操作这些部件的方法。可以在对象和集合之间建立关系,这些关系代表了数据库系统的逻辑结构。RDO是ODBC API的一个浅层界面接口,是专为访问远程ODBC关系数据源而设计的。

  (10)VBSQL:Visual Basic结构化查询语言,是一种基于API的接口方法,几乎与C的DB-Library API相同。VBSQL只支持微软的SQL Server。VBSQL快而且轻,但不支持对象界面。

  尽管数据访问方式有多种,但是适合WINCC通信的方式只有ODBC和ADO,这里重点介绍ODBC接口访问方式。

3 实现方法

  ODBC是一种应用程序的接口,这种接口提供了独立于任何数据管理系统的应用程序编写能力。ODBC通过ODBC驱动程序为不同的数据库供应商的一组应用程序接口提供了特殊的数据库管理系统。用户的应用程序使用这组API来调度ODBC驱动程序。然后驱动程序通过SQL语句与DBMS发生联系。

  下面介绍ODBC数据源。在“我的电脑”中打开“控制面板”中的“管理工具”,即可见ODBC数据源图标。ODBC数据源管理器为配置、添加、删除各种不同的数据源名称提供了为简洁的方法。它使用户可以轻松地完成数据源的配置工作,用户也可以删除原有的DSN,或对先前配置的数据源进行修改。ODBC数据源管理器的具体功能如下[3]。

  (1)用户DSN:ODBC用户数据源存储了如何与指定数据提供者连接的信息。用户数据源只对当前的用户可见,而且只能应用在本机上;

  (2)系统DSN: ODBC系统数据源存储了如何与指定数

  据提供者连接的信息。系统数据源对当前机器上的所有用户可见;

  (3)文件DSN: ODBC文件数据源允许用户连接数据提供者。文件DSN可以由安装了相同驱动程序的用户共享;

  (4)驱动程序: ODBC驱动程序允许那些支持ODBC的程序通过ODBC数据源获取信息。如果安装新的驱动程序,要使用其安装程序;

  (5)跟踪:ODBC跟踪允许创建调用ODBC驱动程序的日志,以供技术人员查看;也可以辅助调试应用程序。Visual Studio跟踪启动Microsoft Visual Studio的ODBC跟踪;

  (6)连接池:连接池允许应用程序重新打开连接句柄,此操作将往返过程存入服务器

  建立数据源:通过对在系统DSN中建立SQL Server数据源test,连接的数据库为test,并测试成功。

  查询数据库:

  Dim cn,strConn,sql,rs

  Dim view1,view2

  Set cn = CreateObject(“ADODB.Connection”)

  Set rs=CreateObject(“ADODB.Recordset”)

  strConn=“test”

  sql=“select * from student order by id ”

  cn.ConnectionString=strConn

  cn.Open

  rs.Open sql,cn

  view1=rs.fields(“id”)

  view2=rs(“name”)

  rs.movenext

  Set rs=Nothing

  Set cn=Nothing

  以上是一个在WINCC中访问数据库、实现查询功能的简单实例。同样,也可以实现插入、删除、修改等功能。以上只是初级的WINCC与数据库通信,要想提高效率,需要进行性能调校。

  数据库性能调校的步骤流程“DETECT”为:

  (1)Discover the problem,发现问题;

  (2)Explore the conditions,探究原因,为问题提供明确的定义与定位;

  (3)Track down possible approaches,提供可能的解决方案;

  (4)Execute the most likely approach,执行有可能的解决方案;

  (5)Check for success(如果需要,可重复之前的步骤),确认解决方案成功与否;

  (6)Tie up loose ends完成收尾工作。

  通过以上调校步骤来对数据库性能进行优化调校。也可以利用相关工具进行性能调校,如SQLDiag.exe、性能监视器、事件日志与事件查看器、网络监视器、SQL Profiler、索引微调向导、Query Analyzer、DBCC、Application Center Test和Web Application Stress Tool等。



  

版权与免责声明

凡本网注明“出处:维库电子市场网”的所有作品,版权均属于维库电子市场网,转载请必须注明维库电子市场网,https://www.dzsc.com,违反者本网将追究相关法律责任。

本网转载并注明自其它出处的作品,目的在于传递更多信息,并不代表本网赞同其观点或证实其内容的真实性,不承担此类作品侵权行为的直接责任及连带责任。其他媒体、网站或个人从本网转载时,必须保留本网注明的作品出处,并自负版权等法律责任。

如涉及作品内容、版权等问题,请在作品发表之日起一周内与本网联系,否则视为放弃相关权利。

上传BOM文件: BOM文件
*公司名:
*联系人:
*手机号码:
QQ:
应用领域:

有效期:
OEM清单文件: OEM清单文件
*公司名:
*联系人:
*手机号码:
QQ:
有效期:

扫码下载APP,
一键连接广大的电子世界。

在线人工客服

买家服务:
卖家服务:

0571-85317607

客服在线时间周一至周五
9:00-17:30

关注官方微信号,
第一时间获取资讯。

建议反馈

联系人:

联系方式:

按住滑块,拖拽到最右边
>>
感谢您向阿库提出的宝贵意见,您的参与是维库提升服务的动力!意见一经采纳,将有感恩红包奉上哦!