|
zijinqiaoshishishujukuruanjianliyuzhileyixiezujian,fenbieshixianbutongdetedinggongneng,zaigongchengzutaideshihou,qiadangliyongzhexiezujianlaishixianmouxiegongneng,huidadaoshibangongbeidexiaoguo。
紫金橋實時數據庫軟件裏預置的曆史查詢組件,能夠按照需求查找一段時間內的曆史數據,然後通過報表顯示出來或者供其他使用。
本示例是通過曆史查詢組件支持的函數,利用腳本對組件進行操作,關於組件支持的具體函數,可以去軟件幫助中查找,這裏不詳述。
下麵主要講解一下曆史查詢組件的具體使用。
功能是這樣的:首shou先xian,將jiang要yao查zha詢xun曆li史shi的de位wei號hao,添tian加jia到dao組zu件jian中zhong,然ran後hou設she定ding要yao查zha詢xun曆li史shi的de起qi始shi時shi間jian和he結jie束shu時shi間jian,再zai設she定ding要yao查zha詢xun的de相xiang鄰lin曆li史shi數shu據ju之zhi間jian的de時shi間jian間jian隔ge,執zhi行xing查zha詢xun並bing把ba結jie果guo顯xian示shi到dao報bao表biao中zhong,功gong能neng完wan成cheng。
在窗口中添加曆史查詢組件,並將組件命名為His1,同時需要使用一個報表進行配合使用,新建一個自由報表命名為Tab1,該報表用來顯示查詢的結果。
下圖是運行後查詢數據的畫麵:

下麵就來說一下各部分的腳本,腳本一共3部分,分別是‘添加位號’、‘開始檢索’按鈕中的腳本,還有一部分是曆史查詢組件中的‘事件腳本’。
首先來看‘添加位號’按鈕中的腳本,如下圖:

因為本例中使用的點名是有規律的,所以使用一個循環腳本一次全添加到曆史查詢組件中,其中主要是使用了曆史查詢組件的函數AddTag(),讀者可以根據自己的實際情況使用該函數向組件中動態的添加要查詢的點。
接下來是‘開始檢索’按鈕的腳本,如下圖:

這裏主要就是曆史查詢組件執行Start()函數,開始曆史檢索,但是由於函數參數需要,先計算出了指定時間範圍內要查找的曆史數據個數以及相鄰曆史的時間間隔。
最後一部分腳本是曆史查詢組件裏的‘事件腳本’,雙擊組件,在彈出窗口單機‘事件腳本’按鈕即進入腳本編輯框,在‘檢索完成時’選項卡裏麵,就是組件檢索完成曆史數據後要執行的腳本,如下圖:

此ci部bu分fen前qian兩liang段duan分fen別bie是shi根gen據ju查zha詢xun到dao的de曆li史shi數shu據ju個ge數shu以yi及ji數shu據ju點dian的de個ge數shu,來lai設she置zhi報bao表biao的de行xing數shu和he列lie數shu,最zui後hou一yi段duan的de循xun環huan語yu句ju是shi把ba查zha詢xun到dao的de數shu據ju添tian加jia到dao報bao表biao中zhong,第di一yi層ceng循xun環huan是shi按an行xing添tian加jia,循xun環huan內nei的de第di一yi行xing是shi利li用yong曆li史shi查zha詢xun組zu件jian的de函han數shuGetTimeText()取得該行曆史數據的時刻,第二層循環是按列添加,循環內的第一行使用GetTagName()函數取得每列的點名,添加到報表的表頭,第二行使用GetCell()取得每列在該行的曆史數據,然後添加到報表中。
以yi上shang就jiu是shi本ben例li中zhong曆li史shi查zha詢xun組zu件jian通tong過guo函han數shu的de使shi用yong,適shi合he需xu要yao查zha詢xun的de位wei號hao較jiao多duo並bing且qie位wei號hao名ming有you一yi定ding規gui律lv的de情qing況kuang,如ru果guo需xu要yao查zha詢xun的de位wei號hao較jiao少shao,可ke以yi直zhi接jie在zai曆li史shi查zha詢xun組zu件jian的de組zu態tai界jie麵mian直zhi接jie添tian加jia,然ran後hou直zhi接jie執zhi行xingStart()函數即可。
另(ling)外(wai),本(ben)例(li)中(zhong)為(wei)了(le)方(fang)便(bian)觀(guan)察(cha),設(she)置(zhi)了(le)曆(li)史(shi)查(zha)詢(xun)組(zu)件(jian)運(yun)行(xing)可(ke)見(jian),實(shi)際(ji)上(shang)該(gai)組(zu)件(jian)默(mo)認(ren)在(zai)運(yun)行(xing)狀(zhuang)態(tai)是(shi)不(bu)顯(xian)示(shi)的(de),也(ye)沒(mei)有(you)必(bi)要(yao)顯(xian)示(shi),這(zhe)一(yi)點(dian)可(ke)以(yi)在(zai)組(zu)件(jian)的(de)組(zu)態(tai)界(jie)麵(mian)中(zhong)勾(gou)選(xuan)或(huo)者(zhe)取(qu)消(xiao)‘運行時可見’即可。
讀者如果有些函數不十分清楚,可以查看紫金橋實時數據庫的幫助文件。以後我們還會陸續推出其他組件的示例說明。
|