現在vr技術發(fā)展怎么樣了【淺談VFP中的RUSHMORE技術】
發(fā)布時間:2020-02-16 來源: 短文摘抄 點擊:
摘要:本文在Visual FoxPro中用實例驗證不同情況下使用RushMore技術對查詢速度的影響,討論這項技術的基本特點,并根據其特點提出優(yōu)化程序結構的方法,以達到加快數據訪問的目的。
關鍵詞:RushMore技術;VFP;索引
中圖分類號:TP311.13 文獻標識碼:A
數據查詢是數據庫技術非常重要的一個部分,數據查詢速度的快慢直接影響到程序的執(zhí)行效率。在VFP中引入索引的概念來解決大型數據庫中數據查詢問題,RushMore技術是VFP中的一種數據查詢技術,它利用索引優(yōu)化對數據的訪問。使用RushMore技術,對一些復雜的表操作時比不使用這項技術要快成百上千倍,因此,能否正確運用這種技術對程序的執(zhí)行效率有著意想不到的作用。
1 RushMore技術實例耗時分析
既然RushMore技術在VFP中有著如此重要的作用,那它是如何加快數據查詢的呢?它在所有的情況下都可以隨意使用嗎?下面,我們利用以下程序對其做一個簡單測試。
首先,建立一個名字為jilu.dbf的表,該表有一個字段“數據 c(10)”,并根據字段“數據”建立一個名為“jilu”的索引。再建立并執(zhí)行如下程序prog1.prg:
use jilu index jilu
for jiluhao=1 to 900000
append blank
replace 數據 with “Visual”
endfor
go 99
replace數據with“FoxPro”
go 34555
replace數據with “FoxPro”
go 75678
replace 數據 with “FoxPro”
該程序的作用是向新建立的jilu表中添加90萬條數據為“Visual”的記錄,并把其中的第99、34555、75678條記錄中的數據更改為“FoxPro”。
1.1 在有索引的表中使用RushMore技術
現在,首先確保jilu表已經打開并且在當前正在使用的工作區(qū)中,然后建立并執(zhí)行如下程序prog2.prg:
set optimize off
ks=second()
display all for 數據=“FoxPro”
js=second()
? “不使用RushMore技術時,程序用時:”+str(js-ks,5,3)+“秒”
set optimize on
ks=second()
display all for 數據=“FoxPro”
js=second()
? “使用RushMore技術時,程序用時:”+str(js-ks,5,3)+“秒”
在這個程序中用變量“ks”記錄查詢開始的時間,用變量“js”記錄查詢結束的時間,然后用表達式“js-ks”計算在查詢三個數據為“FoxPro”的記錄時所需要的耗時量。程序中分別用Set Optimize On和Set Optimize Off開啟和關閉RushMore技術,最終屏幕上會分別顯示出在這兩種情況下程序查找三條“FoxPro”數據所需的時間。表1為五次實驗結果,從該表中我們可以發(fā)現當開啟RushMore技術時耗時量平均值為0.003秒,而關閉RushMore技術時耗時量平均值為3.373秒。很明顯,在有索引的普通表中開啟了RushMore技術后查詢速度能夠快上千倍。
1.2 在沒有索引的表中使用RushMore技術
現在,將jilu表中的索引jilu刪除后再次執(zhí)行程序prog2.prg,實驗結果如表2所示:開啟RushMore技術時耗時量平均值為3.280秒,而關閉RushMore技術時耗時量平均值為3.337秒。從實驗結果中可以發(fā)現在沒有索引的普通表中開啟RushMore技術幾乎沒有加快數據的查詢速度,因此,在沒有索引的表中,RushMore對程序效率沒有明顯的優(yōu)化效果。
1.3 在SQL語句中使用RushMore技術
重新為jilu表建立一個索引,然后再建立并執(zhí)行如下程序prog3.prg:
set safety off
set optimize off
ks=second()
select * from jilu where 數據=“FoxPro” into table temp
js=second() &&記錄操作結束時間
? “不使用RushMore技術時,程序用時:”+str(js-ks,5,3)+“秒”
set optimize on
ks=second()
select * from jilu where 數據=“FoxPro” into table temp1
js=second()
? “使用RushMore技術時,程序用時:”+str(js-ks,5,3)+“秒”
set safety on
表3為五次實驗結果,在該表中發(fā)現當開啟RushMore技術時耗時量平均值為0.002秒,而關閉RushMore技術時耗時量平均值也為0.002秒。若再次把索引刪除,會得到和表2差不多的實驗結果。因此在簡單的SQL語句中,是否開啟RushMore對查詢的速度也沒有多大影響。
2 RushMore技術的特點
從上面的幾個試驗中我們發(fā)現在VFP的非SQL命令中,RushMore技術對命令的優(yōu)化是基于VFP中索引的,它能根據條件表達式自動選擇索引,以提高數據查詢的速度,彌補VFP不能自動選擇索引的缺陷。
2.1 RushMore優(yōu)化原理
RushMore技術是一種數據存取技術,它允許成組的記錄很有效的被存取,在速度上可與經過索引的單一記錄存取相比較,它使VFP能夠在PC機上處理含有數百萬個記錄的真正巨大的表,在速度上能夠和大型機數據庫系統(tǒng)相媲美。
RushMore利用標準的FoxPro B-樹索引,并且不需要任何新類型的文件或者索引。它可以利用VFP的標準索引、壓縮索引,復合或結構化索引。壓縮索引所產生的索引文件的大小只相當于原來索引的六分之一大小。由于壓縮索引文件實際上更小,因而它們能被更快速地單獨處理。這就意味著,處理它們需要更少的磁盤存取,并且更大部分的索引可以保留在VFP內存緩沖區(qū)中。雖然在理論上,復合或結構索引與壓縮索引使用同樣的壓縮技術與方法,但實際上壓縮索引比復合或結構索引操作還是稍快一些。所以,隨著數據庫的增大,使用壓縮索引可獲得較快的速度。RushMore不僅僅充分受益于空間更小的壓縮式索引,對原來的索引格式也同樣有效。當程序執(zhí)行了一條應用RushMore的命令時,它會立即與匹配的記錄組合在一起,再由該命令去操作這一組記錄,顯然,它是將大型數據庫變成了一個小數據庫,對小數據庫的操作當然就會更快。
2.2 RushMore優(yōu)化原則
RushMore并不是對所有非SQL命令都能提高查詢效率。在NEXT、RECORD、ALL、REST四個范圍子句中,它只對ALL和REST有優(yōu)化效果;對于條件語句FOR和WHILE,它只對FOR語句優(yōu)化;在使用NOT條件創(chuàng)建索引時不能優(yōu)化;在使用了惟一索引(UNIQUE)時不能優(yōu)化;在內存很小的計算機上處理數據量很大的表時,RushMore可能會找不到足夠的內存,也是不能優(yōu)化的。
2.3 組合表達式的RushMore優(yōu)化原則
在簡單的語句中,VFP能根據優(yōu)化原則自動選擇關閉還是開啟RushMore。但是,實際案例中我們常常需要在FOR語句中使用AND、OR或NOT這三個邏輯操作符組成邏輯表達式來提高數據的檢索。那么在各種可優(yōu)化或不可優(yōu)化有表達式組合中,整個優(yōu)化結果是什么呢?表4給出了組合表達式的各種優(yōu)化結果。
從表4中可以看出在很多情況下,組合表達式的結果是不能被優(yōu)化的。當這些組合表達式再次組合成更加復雜的表達式時這些全部可優(yōu)化、部分可優(yōu)化或不可優(yōu)化的組合表達式會有一個什么樣的優(yōu)化結果呢?表5列出了這些優(yōu)化種類的結果。
2.4 RushMore技術的優(yōu)化方法
從優(yōu)化規(guī)則表中我們可以看出不同的表達式組合中優(yōu)化情況都不盡相同,在VFP中只要潛在可優(yōu)化的命令中的FOR子句表達式不能被RushMore優(yōu)化,RushMore就被自動禁止。但在少數情況下,VFP自動選擇的RushMore卻不能夠加快數據查詢。譬如說,如果程序中的潛在可優(yōu)化的命令修改了FOR子句中的索引關鍵字,RushMore的記錄集就已經過時了,這時,就應當禁止RushMore以保證獲得表的最新的信息。
所以在特定時刻,我們可以用Set Optimize Off命令或NOOPTIMIZE子句對當前命令關閉RushMore功能,使程序運行效率達到一個最優(yōu)化的效果。
3 結束語
綜上所述,雖然VFP能夠自動開啟或關閉RushMore技術來提高查詢速度,但并不是每次都能得到一個最優(yōu)化的結果,我們應該從實踐全局性來考慮整個程序的執(zhí)行過程,在不同地方人為地開啟或關閉RushMore去獲得一個最佳的優(yōu)化結果。
參考文獻
[1]薩師煊,王珊.數據庫系統(tǒng)概論[M].北京:高等教育出版社,1997.
[2]王利.全國計算機等級考試二級教程――VFP程序設計[M].北京:高等教育出版社,2005.
[3]張洪舉.Visual FoxPro程序設計參考手冊[M].北京:人民郵電出版社,2004.
相關熱詞搜索:淺談 技術 VFP 淺談VFP中的RUSHMORE技術 淺析vfp中的數據緩沖技術 技術實時熱點
熱點文章閱讀