用按钮脚本访问数据库以设置I/O域

要在画面中获得归档数据库中的数据,一共有四个I/O域,1号用于输入开始查询的时间,2号用于输入查询结束的时间,3号用于输入归档周期,这三个I/O域的输入格式都要参考wincc6.0专用归档命令所要求格式,4号用于输出查询结果。因为查询的只是两时间点的差值,所以可以用一个I/O域。那用用做时间输入的,其接收变量的类型设为字符型就可以了,我用VBS做的,但VBS-Editor里面连有个标准函数都没有,也不知道下面编写的脚本对不对,能不能请高手点拔一下,多谢了!!!!
 Dim ConnectionObj As Object
 Dim Connectionstring As String
 Dim TagValue1,TagValue2 As float
 Dim CommandStrTimeStart As string 
 Dim CommandStrTimeEnd As string
 Dim CommandObj As Object

 Connectionstring="Provider=WinCCOLEDBProvider.1;Catalog=CC_archive_08_12_30_10_21_6R;Data Source=.\WinCC"
 'TagValue=HMIRuntime.Tags("speed").Read
 if()
 CommandStrTimeStart="TAG:R,'ProcessValueArchive\\speed','TagStartTime','TagStartTime'+'0000-00-00:00:00:00.500""
 CommandStrTimeEnd="TAG:R,'ProcessValueArchive\\speed','TagEndTime','TagEndTime'+'0000-00-00:00:00:00.500""
 '即模拟语句: Select speed WHERE TagStartTime BETWEEN TagStartTime and TagStartTime + 一个归档周期
 '即对给定时间与归档时间不一致的情况做后向处理.同样也可做前向处理.采取一致约定即可.
 Set ConnectionObj=CreateObject("ADODB.Connection")
 ConnectionObj.ConnectionString=Connectionstring
 ConnectionObj.Open

 Set CommandObj=CreateObject("ADODB.Command")
 with CommandObj
  .ActiveConnection=ConnectionObj

  .CommandText=CommandStrTimeStart
  TagValue1=CommandObj.Execute

  .CommandText=CommandStrTimeEnd 
  TagValue2=CommandObj.Execute
 End With

 'HMIRuntime.Tags("NewTag3").Write TagValue2-TagValue1,资料不全,都不知道用没有这句,只是有read的相关命令.
 TagValue3=TagValue2-TagValue1'如果上一句不行,不知道这句行不行.

 Set CommandObj=Nothing
 ConnectionObj.Close
 Set ConnectionObj=Nothing
 TagValue3=TagValue2-TagValue1

 应该获取变量的值和设置变量的值都应该是不正确的,这先不说吧,就说说查询语句中有哪里要改的吧!!!!如果用C脚本可以的话,那要怎样做呢,更熟悉C脚本,VBS可能访问数据更好用一点吧!!!多谢!!!!

问题补充:
里面的500只是固定的归档周期。
   还用不用再装connection pack授权,wincc6.0 basic没自带吗?
   多谢!!!!!

  还有时间,那再看看有其他人的回答没有再说吧!!!多谢dcount107的回答!!!

 多谢KKZ提醒,不过,好像归档数据库里的表的结构啊什么的都不清楚,而且,归档数据还是压缩储存的。嗯嗯,这个可以用wincc的专用命令来解决。。。多谢哈

 我估计还用vbs了,提到一点资料,一直在翻呵呵,在帮助里有点头绪,明天应该就差不多了吧,不过还有点问题:如果用CommandObj.Execute返回的是一个RecordSet对象,那因为不知道归档数据库中表的字段的名字和顺序,那用RecordSet对象的fields()怎么才能取到自己想要的数据呢???只要把这个问题给解决了,那就好说了。

最佳答案

楼主你的问题看得有点晕,呵呵。取某个时间点的数据这种应用还真是少见。
  1、VBS只有VARIANT变体类型,把as xxx都去掉
  Dim ConnectionObj 
  Dim Connectionstring 
  .......
  2、CommandObj.Execute得到的对象是Recordset,不能直接赋值给float变量。
  3、查询语句:
  dim szStartTime
  szStartTime=HMIRuntime.Tags("TagStartTime").Read
  CommandStr="TAG:R,'ProcessValueArchive\speed',szStartTime,'0000-00-00:00:00:00.500'"
  即可读取所设定时间500MS内的记录

  建议你看一下Connectivity Pack手册,有相关代码。

  访问数据库用C脚本也行,但比较麻烦,还是用VBS吧。

  本机访问不用安装CP授权。
 ---------------------------------------------------------
 不知道的话就用序号,如oRs.Fields(1)、oRs.Fields(2),顺便用oRs.Fields(1).Name看一下字段名称等等,呵呵。
 

提问者对于答案的评价:
哦,那可以看一下字段了,我又重新修改了一下代码,也重新提问了一次,有时间再看看那个吧!!!多谢哈!!!!

原创文章,作者:more0621,如若转载,请注明出处:https://www.zhaoplc.com/plc275066.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2019年6月11日 上午11:16
下一篇 2019年6月11日 上午11:16

相关推荐

  • 用VB全局脚本将数据传送至ACCESS,偶尔会失效。

    用VB全局脚本每分钟将数据传送至ACCESS,一直没有问题,但最近却发现偶尔会无法将数据传送至ACCESS,也任何提示,重启后问题消失。。Option ExplicitF…

    SIMATIC WinCC 2019年6月11日
  • wincc与200通讯?

    现在有16个200PLC站点,分布在4层楼上,层与层站点之间距离大概60米左右,WINCC电脑放在一楼,从4楼拉到3楼用个交换机再从3楼拉到2楼,再加个交换机从2楼拉到一楼,这样站…

    SIMATIC WinCC 2019年6月11日
  • WINCC 7.0怎么安装

    操作系统 是vista 商业版 自定义安装WINCC 7.0时应该选哪些 哪些不选也可以 最佳答案 Windows Vi…

    SIMATIC WinCC 2019年6月11日
  • WINCC以及5611网卡问题

    问题有两个: 1、WINCC在进入某一画面时出现Unhandled exception was raised.Lookfile"c…

    SIMATIC WinCC 2019年6月11日
  • wincc脚本和变量

    对wincc脚本和变量好像弄得不是太明白,那位高手可以解释一下??? 最佳答案 脚本就是 编写代码实现你要的功能(一般不能通过wincc自己来实现的),变量就是下位机内部…

    SIMATIC WinCC 2019年6月11日
  • wincc6.0 不自动删除历史记录

    wincc 6.0项目文件历史记录不会自动删除达到120G,归档参数都是默认值 ,快速和慢速归档为默认值 (1周 1000兆字节 …

    SIMATIC WinCC 2017年12月8日
  • WINCC全用户版 开发版

    请问,WINCC全用户版与开发版有什么区别.我要在两台电脑上装WINCC,购买一套开发版够用吗. 最佳答案 WinCC运行版、开发版与完全版的区别——运行版:只能用于画面运行,不能…

    SIMATIC WinCC 2019年6月11日
  • wincc7.3变量批量实时显示

    wincc7.3变量如何批量在画面实时显示?包括文本与单位(如图)。如果要显示几百个我们不可能一个个都用输入输出域每个编辑吧。 图片说明:    最佳答案 通过…

    2021年7月5日
  • 怎么在wincc运行界面里面增加报警记录?

    我现在的报警记录最多1000条,能不能想办法帮我存储一个月的报警记录。并且在运行画面里面能够查看。那位wincc高手帮忙解决一下,多谢! 问题补充:能否另外做一个界面(或者报表),…

    SIMATIC WinCC 2019年6月11日
  • 关于WINCC中的线

    如何在WINCC 实现  一根线的两端 上下垂直移动,在直线两端距离不变的情况下,假如两端是两个变量控制,线的角度可以随便变化。不知道&nb…

    SIMATIC WinCC 2019年6月11日