zichen8716
我行,我行,我行行行!。
級別: 家園?
精華主題: 0
發(fā)帖數(shù)量: 266 個
工控威望: 527 點(diǎn)
下載積分: 4363 分
在線時間: 59(小時)
注冊時間: 2010-03-25
最后登錄: 2022-12-28
查看zichen8716的 主題 / 回貼
樓主  發(fā)表于: 2014-03-27 14:52
Wincc ODBC連接ACCESS數(shù)據(jù)庫, MshflexGird控件顯示數(shù)據(jù)

wincc自帶安裝SQL數(shù)據(jù)庫,連接不上,退而求其次只能使用ACCESS數(shù)據(jù)庫了,好多人說ODBC方法過時了,但是對于我們這些對數(shù)據(jù)查詢量較小,查詢頻率較低的高級語言初學(xué)者來說,該方法還是比較實(shí)用。
MshflexGird控件,個別電腦上可能沒有注冊,可以在網(wǎng)上下載重新注冊,這次嘗試了好多次可以注冊,但是在添加的時候總是報錯,使用較笨的方法安裝了VB6.0,
MshflexGird控件的屬性比如列數(shù),行數(shù),列寬,列頭注釋等等。百度一下有好多文檔介紹
腳本部分:
Dim objConnection  
Dim strConnectionString
Dim strSQL  
Dim objrs
Dim chaxun
Dim i
Dim j
'定義報表控件
Dim aa
'chaxun=HMIRuntime.Tags("管號查詢輸入").Read
'數(shù)據(jù)庫連接字符串
strConnectionString = "Provider=MSDASQL;DSN=REPORT;UID=;PWD=;"
  strSQL = "select * from report order by 編號 ASC;"
   Set objConnection = CreateObject("ADODB.Connection")
   objConnection.ConnectionString = strConnectionString
objConnection.Open
   Set objrs = CreateObject("ADODB.RecordSet")
  objrs.open  strSQL,objConnection

  '數(shù)據(jù)循環(huán)寫入MSFlexgrid控件
Set aa = ScreenItems("控件5")
aa.rows = 2
'設(shè)置列頭文字
aa.FormatString = "^序號^管號^管徑^管長^壁厚^材質(zhì)^試壓壓力Mpa^保壓時間S^試壓日期^結(jié)束時間^開始時間^操作員^班次^結(jié)論^標(biāo)準(zhǔn)^規(guī)格^溫度℃"
'設(shè)置列寬度
For j=2 To 14
   aa.ColWidth(j)=1500
Next
j=j+1
aa.ColWidth(1)=2000
aa.ColWidth(15)=2000
   '寫入數(shù)據(jù)
On Error Resume Next
objrs.moveFirst
     Do While Not objrs.eof
     For i=0 To 16
       aa.TextMatrix(aa.Rows-1,i)=objrs.fields(i).value
      Next
      aa.Rows=aa.Rows+1
       objrs.movenext
       Loop
  '釋放連接
  objrs.close
Set objrs = Nothing
   objConnection.Close
   Set objConnection = Nothing
失敗并不意味你浪費(fèi)了時間和生命。失敗表明你有理由重新開始
hpwangcheng
級別: 略有小成
精華主題: 0
發(fā)帖數(shù)量: 246 個
工控威望: 359 點(diǎn)
下載積分: 986 分
在線時間: 191(小時)
注冊時間: 2007-10-04
最后登錄: 2024-12-21
查看hpwangcheng的 主題 / 回貼
1樓  發(fā)表于: 2015-01-26 22:04
不錯,謝謝樓主分享