- 相關(guān)推薦
非Access數(shù)據(jù)庫在VB中的編程及應(yīng)用
摘要
Visual Basic有著強大的數(shù)據(jù)庫存取能力,不僅能夠直接支持Ms Access數(shù)據(jù)庫,而且通過其內(nèi)部安裝的ISAM驅(qū)動程序使它能間接支持FoxPro、dBASE等外來數(shù)據(jù)庫。本文不僅從VB數(shù)據(jù)庫體系結(jié)構(gòu)的角度探討了VB對這些外來數(shù)據(jù)庫的支持,還結(jié)合了一些實例具體闡述了使用數(shù)據(jù)庫存取對象變量的方法實現(xiàn)這些外來數(shù)據(jù)庫的新建、庫結(jié)構(gòu)修改、顯示及其運行環(huán)境設(shè)置。
關(guān)鍵詞
Visual Basic Access, 外來數(shù)據(jù)庫,數(shù)據(jù)庫
正文
存取對象變量庫結(jié)構(gòu)作為一個功能較完備的Windows軟件開發(fā)平臺,Visual Basic專業(yè)版提供了對數(shù)據(jù)庫應(yīng)用的強大支持。尤其提供了使用數(shù)據(jù)控件和綁定控制項,使用數(shù)據(jù)庫存取對象變量(Data Access Object Variable),直接調(diào)用ODBC 2.0 API接口函數(shù)等三種訪問數(shù)據(jù)庫的方法。對其標準內(nèi)置的Ms Access數(shù)據(jù)庫,它可以提供不弱于專業(yè)數(shù)據(jù)庫軟件的支持,可以進行完整的數(shù)據(jù)庫維護、操作及其事務(wù)處理。在VB中,將非Access數(shù)據(jù)庫稱為外來數(shù)據(jù)庫。對于FoxPro、dBASE、Paradox等外來數(shù)據(jù)庫。雖然借助VB的Data Manager 能夠?qū)@些數(shù)據(jù)庫進行NEW、OPEN、DESIGN、DELETE等操作,但在應(yīng)用程序的運行狀態(tài)中并不能從底層真正實現(xiàn)這些功能。本文從使用數(shù)據(jù)庫存取對象變量的方法出發(fā),實現(xiàn)了非Access格式數(shù)據(jù)庫(以FoxPro數(shù)據(jù)庫為例)的建新庫、拷貝數(shù)據(jù)庫結(jié)構(gòu)、動態(tài)調(diào)入等操作,闡述了從編程技巧上彌補VB對這些外來數(shù)據(jù)庫支持不足的可行性 。
一 、 VB數(shù)據(jù)庫的體系結(jié)構(gòu)具體的VB的數(shù)據(jù)庫結(jié)構(gòu)。
VB數(shù)據(jù)庫的核心結(jié)構(gòu)是所謂的MicroSoft JET數(shù)據(jù)庫引擎,JET引擎的作用就像是一塊"面 板",在其上可以插入多種ISAM(Indexed Sequential Access Method,即索引順序存取方 法) 數(shù)據(jù)驅(qū)動程序。JET引擎為Access格式數(shù)據(jù)庫提供了直接的內(nèi)部(build-in)支持,這就是VB對Access數(shù)據(jù)庫具有豐富支持的真正原因。
VB專業(yè)版中提供了FoxPro、dBASE(或 Xbase)、Paradox、Btrieve等數(shù)據(jù)庫的ISAM驅(qū)動程序,這就使得VB能支持這些數(shù)據(jù)庫格 式。另外,其他的許多兼容ISAM的驅(qū)動程序也可以通過從廠商的售后服務(wù)得到。因而從理論上說,VB能支持所有兼容ISAM的數(shù)據(jù)庫格式(前提是只需獲得這些數(shù)據(jù)庫的ISAM驅(qū)動接口程序)。
由上可見,Ms JET引擎實質(zhì)上提供了:一個符合ANSI標準的語法分析器;為查詢結(jié)果集的使用而提供的內(nèi)存管理功能;同所支持的數(shù)據(jù)庫的外部接口;為應(yīng)用代碼提供的內(nèi)部接口。實際上,在VB中從一種數(shù)據(jù)庫類型轉(zhuǎn)化為另一種數(shù)據(jù)庫類型幾乎不需要或只需要很少的代碼修改。而且,盡管dBASE、Paradox本身的DDL (Data Definition Language,即數(shù)據(jù)定義語言)和DML(Data Manipulation Language,即數(shù)據(jù)操縱語言)是非結(jié)構(gòu)化查詢的,但它們?nèi)匀豢梢允褂肰B的SQL語句和JET引擎來操縱。
從VB的程序代碼的角度來看,ODBC,ISAM驅(qū)動程序以及Ms Access數(shù)據(jù)庫的整個外部結(jié)構(gòu)夠可以統(tǒng)一為一個一致的編程接口。也即是說,提供給VB應(yīng)用程序員的記錄集對象視圖同所使用的數(shù)據(jù)庫格式及類型是相互獨立的。即對FoxPro等數(shù)據(jù)庫仍然可以使用眾多的數(shù)據(jù)庫存取對象變量,這就為非Access數(shù)據(jù)庫的訪問提供了最重要的方法。
二 、使用非Access數(shù)據(jù)庫時的參數(shù)設(shè)置及配置文件的參數(shù)讀取如果在VB的程序中使用了數(shù)據(jù)庫的操作,將應(yīng)用程序生成EXE文件或打包生成安裝程序后,則必須提供一個配置 (.INI)文件,在INI文件中可以對不同類型的數(shù)據(jù)庫進行設(shè)置。如果找不到這個INI文件, 將會導致不能訪問數(shù)據(jù)庫。通常情況下,INI文件的文件名和應(yīng)用程序的名稱相同,
[1] [2] [3] [4]
【非Access數(shù)據(jù)庫在VB中的編程及應(yīng)用】相關(guān)文章:
淺談VB語言在道路設(shè)計中的應(yīng)用04-27
彩虹及在非均勻球中的應(yīng)用04-28
Microsoft Access 2000數(shù)據(jù)庫在《物理化學實驗》數(shù)據(jù)處理系統(tǒng)中的應(yīng)用04-28
淺談ActionScript編程在教學課件制作中的應(yīng)用04-29
多重網(wǎng)格法在非結(jié)構(gòu)網(wǎng)格中的應(yīng)用04-27
雙案例在財經(jīng)院校軟件技術(shù)基礎(chǔ)(VB)課程中的應(yīng)用04-29