1、1WinCC V6.2 数据库访问我们现在的 WinCC 教材是以 WinCC V6.0 SP3 为软件平台而开发的,而之后, Siemens又推出了 V6.2、V7.0 版本的 WinCC。目前,BU 大力推的是 V7.0 的 WinCC,我们的 WinCC教材也准备升级为 V7.0 版本。但从用户的角度来说,对 V7.0 版本的 WinCC 还有一个逐步接受的过程,以后,我们碰到的客户,可能很多还是使用 V6.2 版本的软件。所以,我们还是有必要熟悉一下 WinCC V6.2。本文主要介绍 WinCC V6.2 的数据库访问,由于 WinCC V7.0 和WinCC V6.2 采用的都是
2、SQL Server 2005 数据库,故本文对了解 WinCC V7.0 的数据库访问也是有帮助的。(一)若采用 WinCC V6.2,原来的教材中有关操作和界面的变化1. 打开 SQL Server 管理工具SQL Server 2005 和 SQL Server 2000 在界面上还是有很大不同的,原来的企业管理器变成了SQL Server Management Studio (SSMS)。图 1. 启动 SSMS2. 选择身份认证方式:WinCC 系统在 SQL Server 中注册了自己的账户,如 WinCCAdmin、WinCCConnect 等,所以,WinCC 使用到了 SQL
3、 Server 的认证方式。外部程序访问数据库时,可以采用 Windows 集成的认证方式。2图 2. 选择身份认证方式图 3. WinCC 在 SQL Server 中注册的用户3. 查看 ValueID 和 ValueName 的对应关系3图 4. 查看 ValueID 和 ValueName 的对应关系4. 查看组态的消息图 5. 查看组态的消息5. 查看归档片段的消息4图 6. 查看归档片段的消息6.数据传输服务图 7. 选择数据导出服务5图 8. 选择数据源(与原来的 DTS 类似)图 9. 设置数据源6图 10. 选择目标地图 11. 选择查询并传输7图 12. 输入查询语句图 1
4、3. 源和目标列的对应关系8图 14. 选择立刻执行传输图 15. 传输执行前的提示9图 16. 传输执行结果报告图 17. 查看传输结果107. 在 Excel 中编程利用 WinCC OLE-DB 访问 WinCC 数据库方法及程序同原来的教材,原来的教材的程序同样适用。8 归档变量设置和归档数据库片段设置和原来版本类似。(二)有关 WinCC V6.2 数据库访问的一些背景知识1. WinCC 数据库的变迁:Sybase Anywhere 7(V6.0 之前) - Microsoft SQL Server 2000(V6.0) - Microsoft SQL Server 2005( V
5、6.2,V7.0 ) 2. WinCC V6.2 开始,慢速归档和快速归档都采用了压缩的方式存储在数据库的相应表中(Microsoft SQL Server 2005 之后) ,访问这些经过压缩的二进制数据块,需要采用独特的 OLE DB provider WinCC OLE-DB provider,而普通的 Microsoft OLE DB provider 无法读取并解密出 WinCC 的归档数据。3. WinCC 和 WinCCFlexibel 项目各自生成一个实例。所谓的“实例” ,就是一个 SQL Server 数据库引擎。SQL Server 支持在同一台计算机上同时运行多个 SQ
6、L Server 数据库引擎实例,每个SQL Server 数据库引擎实例各有一套不为其他实例共享的系统及用户数据库。各实例的运行是独立的,一个实例的运行不会受其他实例运行的影响,也不会影响其他实例的运行。在一台计算机上安装多个 SQL Server 实例,就相当于把这台计算机模拟成多个数据库服务器,而且这些模拟的数据库服务器是独立且同时运行的。4. WinCC 归档变量的时间采用通用协调时(UTC, Universal Time Coordinated)时间,滞后北京时间 8 小时,所以得到归档数据后,时间需要做调整。例如在 VB 中可以使用 DateAdd 函数来进行转换。5. ODBC
7、是曾经的数据库通信标准;在组件/对象盛行的大趋势下,微软打算用 OLE-DB 来取代 ODBC;ADO 是简单的应用程序层面的数据库访问方法, 构建在 OLE-DB 之上。ODBC(Open Database Connectivity)是一个数据库访问的标准接口。ODBC 能够动态装载各个数据库的 CLI,并把对 ODBC 的调用转换为 CLI 调用。通过这一标准的接口,开发者就可以不必关心具体的数据库管理系统(DBMS)的实现细节。只要相应类型数据库提供了ODBC 驱动程序,就可以同过 ODBC 来实现对数据库的访问。至此,数据库应用程序就独立于具体的数据库管理系统了。Microsoft C
8、OM 技术发展起来以后,微软提出了 OLE-DB( Object Linking Server=.WINCC;uid=;pass=;database=guowincc“Set objConnection = CreateObject(“ADODB.Connection“)objConnection.ConnectionString = strConnectionString objConnection.open 而 insert 语句需要用到 objConnection 这个对象:strSql = “insert into testwincc values(NewTag1_inter,“ Se
9、t objCommand = CreateObject(“ADODB.Command“) with objCommand .ActiveConnection = objConnection .CommandText = strSql End With objCommand.Execute 然后断开连接也要用到 objConnection 对象:Set objCommand = Nothing objConnection.Close Set objConnection = Nothing但是全局脚本就没有参数传递,这要怎么办呢?我是想在用全局脚本写 sql 的时候不要它老是连接写断开,连接写断开
10、我只想用这样的顺序:连接写.写. 写.断开 问题补充:请问一下,wincc 里的内部变量有 Script 和 TagLoggingRt,这两个有什么区别啊?提问者: guopei296 - 助理 二级 最佳答案 WinCC 的 VBS 虽可以生命 Public 变量,但作用域仅限于本画面。如果你的 WinCC 版本=V6.0 SP3,则可以使用 Dataset 对象,该对象可以在不同的 VBS 脚本中进行访问。下面是个简单的例子:1、连接Dim objConnection,strConnectionStringstrConnectionString =“Driver=SQL Server;Se
11、rver=.WINCC;uid=;pass=;database=guowincc“ 14Set objConnection = CreateObject(“ADODB.Connection“) objConnection.ConnectionString = strConnectionString objConnection.open HMIRuntime.DataSet.Add “objConnection“,objConnection2、全局动作中引用Dim objConnectionobjConnection= HMIRuntime.DataSet(“objConnection“).Va
12、luewith objCommand .ActiveConnection = objConnection xxxxxxxx3、关闭连接:Dim objConnectionobjConnection= HMIRuntime.DataSet(“objConnection“).ValueobjConnection.Close Set objConnection = Nothing 本日:1 本周: 9 本月:12 总数:381 返回上一页 打 印 0好的评价 如果您觉得此文章好,就请您0%(0) 差的评价 如果您觉得此文章差,就请您0%(0) 中查找“wincc 用 vb 脚本写自定义的 sql 数据库问题”更多相关内容 中查找“wincc 用 vb 脚本写自定义的 sql 数据库问题”更多相关内容 上一篇文章:vb 在一个窗体中调用另一窗体的程序 下一篇文章:急求 vb 程序设计答案 文章评论评论内容只代表网友观点,与本站立场无关! 评论摘要( 共 0 条,得分 0 分,平均 0 分) 查看完整评论