


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
如何提高VFP中數(shù)據(jù)表的安全性本文分析了VFP中游標(biāo)、數(shù)據(jù)緩沖、事務(wù)處理、數(shù)據(jù)備份和恢復(fù)的功能以及它們?cè)谔岣邤?shù)據(jù)表安全性中的應(yīng)用。標(biāo)簽:VisualFoxPro游標(biāo)視圖CursorAdapter數(shù)據(jù)緩沖事務(wù)處理VFPVisualFoxProFoxpro序設(shè)計(jì)語言,VFPVFP編寫的,可以說,從操縱數(shù)據(jù)的角度來說,VFPVFPVFP生文件錯(cuò)誤,WordWord是因?yàn)樗褂昧伺R時(shí)文件,在Word打開某文件時(shí),可以看到相應(yīng)目錄下產(chǎn)生的.TmpVFP能,而設(shè)計(jì)員在程序中有沒有考慮過這種斷電情況的發(fā)生?采取了哪些避免方VFP以及它們?cè)谔岣邤?shù)據(jù)表安全性中的應(yīng)用。(一)游標(biāo)(Cursor)VFP雖然也是“表但它是屬于“內(nèi)存型”“表”就失效,便不存在安全性的問題。VFPSQLSelect產(chǎn)生的查詢結(jié)Cursor。可以說,VFPCursorCursorAdapter。1、視圖視圖是從一個(gè)表或多個(gè)表或其他視圖上導(dǎo)出的“表SELECT庫中分離成為游離數(shù)據(jù),以便在主系統(tǒng)之外收集和修改數(shù)據(jù)。當(dāng)我們用了視圖之后,更改視圖的同時(shí)表沒有立即更改,而是在發(fā)送簡單,由數(shù)據(jù)表創(chuàng)建一個(gè)視圖,在更新條件選擇“SQL更新”,便可以把它添加到數(shù)據(jù)環(huán)境中和表一樣使用。2、CursorAdapterCursorAdapterVFP8.0推出的一個(gè)最重要的、也是最精彩的新功能。CursorAdapter來訪問本地?cái)?shù)據(jù)ODBCADOXMLVFP8.0CursorAdapter后,只需要很少的工作就可以設(shè)置好那些屬性表示要選用什么方式訪問數(shù)據(jù)源,如果使用VFP“Native”;Tables屬性設(shè)置為VFPSelectCmd屬性是一個(gè)用來取得數(shù)據(jù)的SQLSelect可以設(shè)置為:select字段,from表名。設(shè)置完畢,就會(huì)在數(shù)據(jù)環(huán)境設(shè)計(jì)器中函數(shù)來更新數(shù)據(jù)源。CursorAdapter與視圖有很多類似的地方:SQLselect語句,定義哪函數(shù)發(fā)送Select語句是預(yù)先定義好的,無法動(dòng)態(tài)去修改它。而對(duì)象Cursor(處理)管理器CursorAdapter與數(shù)據(jù)庫無關(guān),它完全是程序設(shè)計(jì)上SelectCmd屬性來改變?nèi)〉檬裁磾?shù)據(jù)。(二)數(shù)據(jù)緩沖數(shù)據(jù)緩沖是用來保護(hù)對(duì)表記錄所作的數(shù)據(jù)更新及數(shù)據(jù)維護(hù)操作的一種技術(shù)。VFP為啟用數(shù)據(jù)緩沖的表在內(nèi)存中開辟一并不直接對(duì)硬CursorSetprop()提交VFP新使用緩沖,選擇表緩沖。VFP命令,然后鎖定并更新已編輯的記錄。開放式緩沖是更新記錄的有緩沖訪問數(shù)據(jù)的方法:在表單的數(shù)據(jù)環(huán)境中,將數(shù)據(jù)表的屬性BufferModeOverride設(shè)為3開放式行緩沖或5開放式表緩沖;在”保存”代碼中加入:=tableupdate(.t.)&&實(shí)施對(duì)原表的更改在”還原”代碼中加入:=tablerevert(.t.)&&放棄所有表的更改(三)事務(wù)處理數(shù)據(jù)庫的更新操作,就可以回滾整個(gè)事務(wù)處理,而不執(zhí)行任何更新。VFPTRANSACTION命令用來初ROLLBACK命令用來取消最近一條BEGIN語句以來所做的全部修改,ENDTRANSACTION命令用來鎖定記錄,提交最近BEGINTRANSACTION記錄。一個(gè)事務(wù)處理起始于BEGINTRANSACTION命令,以ENDTRANSACTIONROLLBACK命令終止。為了保存所做的修改并終止事務(wù)處ENDTRANSACTION命令。如果事務(wù)處理失敗(如服務(wù)器有故障或ROLLBACK命令,事務(wù)處理中的文件就恢復(fù)成原狀態(tài)。示例:use表名begaintran&&dele刪除一條記錄rollbackdele刪除一條記錄endtran&&結(jié)束事務(wù)處理,清除事務(wù)處理跟蹤日志VFP使用事務(wù)處理的原則:事務(wù)以BEGINTRANSACTION開始,以ENDTRANSACTION或ROLLBACK結(jié)束,必須成對(duì)使用;除非應(yīng)用程序終,事務(wù)一旦開始,直到遇到ENDTRANSACTION或ROLLBAKC語句期間,將保持有效;緩沖區(qū)中的數(shù)據(jù)比磁盤中的數(shù)據(jù)優(yōu)先級(jí)高,即事務(wù)處理優(yōu)先使用緩沖區(qū)中的數(shù)據(jù);如果在事務(wù)處理過程中應(yīng)用程序終止,則取消事務(wù)對(duì)表的所有操作;事務(wù)處理可以嵌套使用,函數(shù)TXTLEVEL()確定當(dāng)前事務(wù)處理的等級(jí),最大值為5,表示事務(wù)最多嵌套五層,TXTLEVEL()為0 表示當(dāng)前無事務(wù)處理;BEGINTRANSACTION和ENDTRANSACTION(ROLLBACK)采用最近優(yōu)先原則匹配最內(nèi)層的更新優(yōu)先于嵌套事務(wù)處理中的其他更新;直接或間接調(diào)用事務(wù)時(shí),VFP自動(dòng)加鎖,直到ENDTRANSACTION(ROLLBACK)時(shí)自動(dòng)解鎖。(四)備份與恢復(fù)備份數(shù)據(jù)時(shí)我們常用的方法是:Copyto命令生成備份表文件,如果原數(shù)據(jù)表有備注字段還會(huì)同時(shí)生成一個(gè)同名的備注文件。示例:bf=ALLTRIM(PUTFILE(“表文件:”,”“,”dbf”))SELECT表名if!empty(bf)COPYTO“&bf”nn=MESSAGEBOX(“數(shù)據(jù)導(dǎo)出完畢...”,0+64,”信息”)endif恢復(fù)數(shù)據(jù)時(shí)所用的方法是:讀取備份文件,將原表的記錄全部刪除,用Append命令將備份文件的數(shù)據(jù)加入到數(shù)據(jù)表中。示例:hf=ALLTRIM(GETfile(“dbf”,this.Caption,“選擇”))if!empty(hf)SELECTDELETEALLAPPENDFROM“&hf”nn=MESSAGEBOX(“數(shù)據(jù)導(dǎo)入完畢...”,0+64,”信息”)ENDIF利用以上程序,可以實(shí)現(xiàn)對(duì)VFP數(shù)據(jù)表的備份與恢復(fù)。總結(jié):綜上所述,VFP提供的游標(biāo)、數(shù)據(jù)緩沖、事務(wù)處理可以有效的保護(hù)數(shù)據(jù),它們?cè)诔绦蛟O(shè)計(jì)中的結(jié)合使用能大大降低程序意外中斷引起的數(shù)據(jù)表損壞,同時(shí)程序設(shè)計(jì)中要有完善的數(shù)據(jù)備份和恢復(fù)功能,在程序遭遇磁盤故障及計(jì)算機(jī)病毒等情況時(shí)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025小學(xué)五年級(jí)語文下冊(cè)知識(shí)點(diǎn)教學(xué)計(jì)劃
- 系統(tǒng)抗性信號(hào)傳導(dǎo)-洞察及研究
- 高校校園文明禮儀德育架構(gòu)及職責(zé)
- 老年針刺操作規(guī)范及流程
- 初三化學(xué)實(shí)驗(yàn)課程教學(xué)計(jì)劃
- 監(jiān)理在第三方人才測評(píng)中的管控措施
- 2025屆福建省六校高二物理第二學(xué)期期末統(tǒng)考模擬試題含解析
- 2025幼兒園春季教職工健康管理計(jì)劃
- 2025-2026學(xué)年度小學(xué)科技創(chuàng)新活動(dòng)計(jì)劃
- 設(shè)備長周期安全穩(wěn)定經(jīng)濟(jì)運(yùn)行的維護(hù)措施
- 廣州市藝術(shù)中學(xué)招聘教師考試真題2024
- 工業(yè)自動(dòng)化設(shè)備保修及維修管理措施
- 期末作文預(yù)測外研版七年級(jí)英語下冊(cè)
- 2025-2030中國兒童魚油行業(yè)銷售動(dòng)態(tài)及競爭策略分析報(bào)告
- 統(tǒng)編版五年級(jí)升六年級(jí)語文暑期銜接《課外閱讀》專項(xiàng)測試卷及答案
- 小小理財(cái)家課件
- DB43-T 2622-2023 醫(yī)療導(dǎo)管標(biāo)識(shí)管理規(guī)范
- 譯林版一年級(jí)下冊(cè)全冊(cè)英語知識(shí)點(diǎn)梳理
- 案場物業(yè)制度管理制度
- 護(hù)理事業(yè)十五五發(fā)展規(guī)劃(2026-2030)
- CJ/T 316-2009城鎮(zhèn)供水服務(wù)
評(píng)論
0/150
提交評(píng)論