找答案的高端用户(找答案钻石及双钻级别的用户)将尽可能从此问题下的所有回
答中,为您推荐最佳答案。届时您可以根据推荐数采纳答案。
如果自提问时间起7天内您仍无法选出最佳答案,您可以选择“无满意答案”关闭此问题。
问题
取消精华
首页精华问答
取消推荐
高端用户推荐
申请置评
已申请置评
修改
修改标签
添加标签
官方认证
取消官方认证
修改标签
添加标签
转移分类
删除
{{itemCategory}}
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可能访问数据更好用一点吧!!!多谢!!!!
还有时间,那再看看有其他人的回答没有再说吧!!!多谢dcount107的回答!!!
多谢KKZ提醒,不过,好像归档数据库里的表的结构啊什么的都不清楚,而且,归档数据还是压缩储存的。嗯嗯,这个可以用wincc的专用命令来解决。。。多谢哈
我估计还用vbs了,提到一点资料,一直在翻呵呵,在帮助里有点头绪,明天应该就差不多了吧,不过还有点问题:如果用CommandObj.Execute返回的是一个RecordSet对象,那因为不知道归档数据库中表的字段的名字和顺序,那用RecordSet对象的fields()怎么才能取到自己想要的数据呢???只要把这个问题给解决了,那就好说了。
收藏({{answerDetail.Q_FavoriteCounts}})
手机扫码追踪该问题,
觉得实用,立即去分享!
点击复制链接
专家建议
取消最佳答案
修改
楼主你的问题看得有点晕,呵呵。取某个时间点的数据这种应用还真是少见。
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看一下字段名称等等,呵呵。
等您来回答
换一换
{{item.CoinValue}}西币
{{item.VisitNum}}人想问
本版相关问题
换一换
专家置评
首次回答问题,获得
双倍西币积分!
立即成为技术知识分享的一员!
欢迎您访问支持中心!
丰富的视频,全方位的文档,大量的网友交流精华……
为了更好的完善这些内容,我们诚邀您在浏览结束后,花20秒左右的时间,完成一个用户在线调查!
感谢您的支持!

西门子商城