技術(shù)頻道

      紫金橋軟件中的人工錄入歷史數(shù)據(jù)的同步

      在一些大型的生產(chǎn)管理系統(tǒng)中,往往都會(huì)應(yīng)用到人工錄入歷史數(shù)據(jù)功能,從而對(duì)生產(chǎn)數(shù)據(jù)進(jìn)行系統(tǒng)的管理,這部分的數(shù)據(jù)不能夠在儀表中采集到,只能通過人為的填寫,這部分?jǐn)?shù)據(jù)不但要存儲(chǔ)到客戶端,還要上傳到服務(wù)器端進(jìn)行顯示,這樣就會(huì)引發(fā)一個(gè)關(guān)鍵問題:如何做到服務(wù)器端與客戶端的數(shù)據(jù)同步?下面提供三種解決方案。
      第一種:服務(wù)器端直接調(diào)取客戶端數(shù)據(jù)。
      這種方案制作過程比較簡(jiǎn)單,只需要在服務(wù)器端針對(duì)于相應(yīng)的客戶端建立一個(gè)數(shù)據(jù)源,選擇遠(yuǎn)程節(jié)點(diǎn),并將IP指向客戶端即可。如下圖所示。
      其中:主機(jī)名/地址為客戶端的IP地址。當(dāng)這一切配置好之后,只需在自由報(bào)表中調(diào)用GetHisDataEx()函數(shù),在運(yùn)行的情況下就可以調(diào)取到客戶端的歷史數(shù)據(jù)。GetHisDataEx()函數(shù)的聲明如下:
      GetHisDataEx(string DataSource,string VarName,int StartTime,int MilliSecond)。
      其中:DataSource要填寫相應(yīng)客戶端的數(shù)據(jù)源名稱,VarName要填寫該數(shù)據(jù)源下的數(shù)據(jù)庫(kù)變量名稱。這樣當(dāng)系統(tǒng)運(yùn)行時(shí),在服務(wù)器端就可以調(diào)取到客戶端的數(shù)據(jù)了。但這中方案存在一個(gè)弊端,即當(dāng)客戶端停止運(yùn)行或著客戶端與服務(wù)器端通訊終端時(shí),那么在服務(wù)器端則看不到客戶端的任何數(shù)據(jù)。
      第二種:客戶端直接向服務(wù)器端插入歷史數(shù)據(jù)。
      這種方案與第一種方案基本類似,需要在客戶端建立一個(gè)數(shù)據(jù)源,并指向服務(wù)器端,客戶端在保存歷史數(shù)據(jù)時(shí)調(diào)用InsertHisDataEx()函數(shù),該函數(shù)的聲明如下:
      InsertHisDataEx(string DataSource,string VarName,real Data,int StartTime,int MilliSec)。
      其中,DataSource要填寫相應(yīng)服務(wù)器端的數(shù)據(jù)源名稱,VarName要填寫該數(shù)據(jù)源下的數(shù)據(jù)庫(kù)變量名稱。這樣在客戶端與服務(wù)器端通訊正常的狀態(tài)下,保存動(dòng)作執(zhí)行時(shí),客戶端就會(huì)直接向服務(wù)器端插入歷史數(shù)據(jù)。服務(wù)器端在報(bào)表中調(diào)用GetHisDataEx()函數(shù)就可以調(diào)取到本地相應(yīng)的數(shù)據(jù)。這種方案的弊端則是增大了客戶端的負(fù)荷,會(huì)導(dǎo)致客戶端運(yùn)行速度變慢。優(yōu)點(diǎn)則是在服務(wù)器端和客戶端都存有數(shù)據(jù),相當(dāng)于做了一次數(shù)據(jù)備份。
      第三種:客戶端觸發(fā)服務(wù)器端自行保存歷史數(shù)據(jù)。
      這種方案制作過程相對(duì)于前兩種要復(fù)雜一些,首先要在服務(wù)器端建立一個(gè)數(shù)據(jù)源指向客戶端,并在服務(wù)器端建立相應(yīng)的點(diǎn)關(guān)聯(lián)到客戶端的點(diǎn)上。其次,在服務(wù)器端數(shù)據(jù)庫(kù)全局腳本中編寫一段存儲(chǔ)這些點(diǎn)PV值的歷史數(shù)據(jù)的腳本,通過一個(gè)標(biāo)志位觸發(fā)存儲(chǔ)動(dòng)作。客戶端在保存歷史數(shù)據(jù)時(shí)要把相應(yīng)點(diǎn)的PV值也做修改,這樣服務(wù)器上做了相應(yīng)關(guān)聯(lián)的點(diǎn)的PV值也會(huì)跟著做改變。在通過客戶端觸發(fā)服務(wù)器端的保存標(biāo)志位,服務(wù)器端就會(huì)自行的將這部分?jǐn)?shù)據(jù)存儲(chǔ)下來,在運(yùn)行的狀態(tài)下通過報(bào)表調(diào)用GetHisDataEx()把歷史數(shù)據(jù)調(diào)取出來即可。還可以在數(shù)據(jù)源高級(jí)選項(xiàng)中把數(shù)據(jù)故障恢復(fù)勾選上,如下圖所示。即使因通訊中斷,客戶端無法觸發(fā)服務(wù)器端的保存標(biāo)志而導(dǎo)致兩端數(shù)據(jù)不同步,在通訊恢復(fù)時(shí),客戶端也會(huì)自動(dòng)的把這部分?jǐn)?shù)據(jù)長(zhǎng)傳到服務(wù)器中,這樣就更加全面的保證了兩端數(shù)據(jù)的同步性。
      第三種方案完全的解決了第二種方案中增加了客戶端負(fù)荷的弊端,也解決了第一種方案中通訊中斷時(shí)服務(wù)器端看不到之前歷史數(shù)據(jù)的弊端,同時(shí)還具備了前兩種方案中不具備的優(yōu)勢(shì):故障數(shù)據(jù)恢復(fù),因此在類似這種的案例中,推薦使用第三種方案。

      文章版權(quán)歸西部工控xbgk所有,未經(jīng)許可不得轉(zhuǎn)載。

      主站蜘蛛池模板: 国产成人精品一区二三区| 国产在线不卡一区二区三区| 国偷自产视频一区二区久| 天天视频一区二区三区| 精品福利一区3d动漫| 国产在线视频一区| 久久久精品人妻一区二区三区蜜桃| 色婷婷AV一区二区三区浪潮| 国产免费无码一区二区| 国产凹凸在线一区二区| 日韩精品区一区二区三VR| 无码精品一区二区三区| 国产午夜三级一区二区三| 亚洲国产成人精品无码一区二区| 精品国产一区二区三区AV| 国产乱码精品一区二区三| 免费无码VA一区二区三区| 国产三级一区二区三区| 无码av免费一区二区三区| 日韩久久精品一区二区三区 | 国产乱码精品一区二区三区四川人| 精品无码成人片一区二区| 精品国产一区AV天美传媒| 国产成人精品一区二三区在线观看 | 国产精品伦子一区二区三区| 亚洲国产精品一区二区久久hs| 国产产一区二区三区久久毛片国语| 狠狠色婷婷久久一区二区| 日韩精品一区二三区中文| 大帝AV在线一区二区三区| 亚洲宅男精品一区在线观看| 国产亚洲一区二区精品| 香蕉久久AⅤ一区二区三区| 韩国一区二区视频| 伊人无码精品久久一区二区| 国产成人久久精品一区二区三区| 日本一区二区在线不卡| 国产成人av一区二区三区在线| 国模视频一区二区| 内射一区二区精品视频在线观看| 精品人妻少妇一区二区三区不卡|