亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Access > 正文

非Access數據庫在VB中的編程及應用

2024-09-07 19:05:33
字體:
來源:轉載
供稿:網友

存取對象變量庫結構作為一個功能較完備的Windows軟件開發平臺,Visual Basic專業版提供了對數據庫應用的強大支持。尤其提供了使用數據控件和綁定控制項,使用數據庫存取對象變量(DataAccessObject Variable),直接調用ODBC 2.0 API接口函數等三種訪問數據庫的方法。對其標準內置的Ms Access數據庫,它可以提供不弱于專業數據庫軟件的支持,可以進行完整的數據庫維護、操作及其事務處理。在VB中,將非Access數據庫稱為外來數據庫。對于FoxPro、dBASE、Paradox等外來數據庫。雖然借助VB的Data Manager 能夠對這些數據庫進行NEW、OPEN、DESIGN、DELETE等操作,但在應用程序的運行狀態中并不能從底層真正實現這些功能。本文從使用數據庫存取對象變量的方法出發,實現了非Access格式數據庫(以FoxPro數據庫為例)的建新庫、拷貝數據庫結構、動態調入等操作,闡述了從編程技巧上彌補VB對這些外來數據庫支持不足的可行性 。

一、VB數據庫的體系結構具體的VB的數據庫結構。

VB數據庫的核心結構是所謂的MicroSoft JET數據庫引擎,JET引擎的作用就像是一塊"面板",在其上可以插入多種ISAM(Indexed Sequential Access Method,即索引順序存取方 法) 數據驅動程序。JET引擎為Access格式數據庫提供了直接的內部(build-in)支持,這就是VB對Access數據庫具有豐富支持的真正原因。

VB專業版中提供了FoxPro、dBASE(或 Xbase)、Paradox、Btrieve等數據庫的ISAM驅動程序,這就使得VB能支持這些數據庫格 式。另外,其他的許多兼容ISAM的驅動程序也可以通過從廠商的售后服務得到。因而從理論上說,VB能支持所有兼容ISAM的數據庫格式(前提是只需獲得這些數據庫的ISAM驅動接口程序)。

由上可見,Ms JET引擎實質上提供了:一個符合ANSI標準的語法分析器;為查詢結果集的使用而提供的內存管理功能;同所支持的數據庫的外部接口;為應用代碼提供的內部接口。實際上,在VB中從一種數據庫類型轉化為另一種數據庫類型幾乎不需要或只需要很少的代碼修改。而且,盡管dBASE、Paradox本身的DDL (Data Definition Language,即數據定義語言)和DML(Data Manipulation Language,即數據操縱語言)是非結構化查詢的,但它們仍然可以使用VB的SQL語句和JET引擎來操縱。

從VB的程序代碼的角度來看,ODBC,ISAM驅動程序以及Ms Access數據庫的整個外部結構夠可以統一為一個一致的編程接口。也即是說,提供給VB應用程序員的記錄集對象視圖同所使用的數據庫格式及類型是相互獨立的。即對FoxPro等數據庫仍然可以使用眾多的數據庫存取對象變量,這就為非Access數據庫的訪問提供了最重要的方法。

二 、使用非Access數據庫時的參數設置及配置文件的參數讀取如果在VB的程序中使用了數據庫的操作,將應用程序生成EXE文件或打包生成安裝程序后,則必須提供一個配置 (.INI)文件,在INI文件中可以對不同類型的數據庫進行設置。如果找不到這個INI文件, 將會導致不能訪問數據庫。通常情況下,INI文件的文件名和應用程序的名稱相同,所以如果沒有指明,VB的程序會在Windows子目錄中去找和應用程序同名的INI文件??梢允褂肰B中的SetDataAccessOptions語句來設置INI文件。

SetDataAccessOptions語句的用法如下:SetDataAccessOptions 1 ,IniFileName其中IniFileName參數指明的是INI文件的帶路徑的文件名。值得注意的是,當應用程序找不到這個INI文件時,或在調用 OpenDataBase函數時對其Connect參數值沒有設定為VB規定的標準值,如對FoxPro 2.5格式設定為了" FoxPro;"(應為" FoxPro 2.5; "),或者沒有安裝相應的ISAM驅動程序,則此時VB會顯示一條錯誤信息" Not Found Installable ISAM "。通常,INI文件在應用程序分發出去以前已經生成,或者在安裝時動態生成,也可以在應用程序中自己生成。 通常這種 INI文件中有" [Options]"、"[ISAM]"、" [Installed ISAMs]"、"[FoxPro ISAM]"、"[dBASE ISAM] " 、" [Paradox ISAM] "等設置段,對于一個完整的應用程序則還應有一個屬于應用 程序自己的設置段如" [MyDB]”??稍谄渲性O置DataType、Server、DataBase、 OpenOnStartup、DisplaySQL、QueryTimeOut等較為重要的數據庫參數,并以此限定應用程序一般的運行環境。 Windows API接口函數在Kernel.exe動態鏈接庫中提供了一個OSWritePrivateProfileString函數,此函數能按Windows下配置文件(.INI)的書寫格式寫入信息。

在通常情況下,應用程序還需要在運行時讀取配置文件內相關項的參數。比如PageTimeOut(頁加鎖超時時限)、MaxBufferSize(緩沖區大小)、LockRetry(加鎖失敗時重試次數)等參數,通過對這些參數的讀取對應用程序運行環境的設定、潛在錯誤的捕獲等均會有很大的改善。

三 、數據存取對象變量對外來數據庫編程的方法及其實例在VB專業版數據庫編程的三種方法中,第二種-使用數據庫存取對象變量(DAO)的方法最具有功能強大、靈活的特點。 它能夠在程序中存取ODBC 2.0的管理函數;可以控制多種記錄集類型:Dynaset,Snapshot 及Table記錄集合對象;可以存儲過程和查詢動作;可以存取數據庫集合對象,例如 TableDefs,Fields,Indexes及QueryDefs;具有真正的事物處理能力。因而,這種方法對數據庫處理的大多數情況都非常適用。

由于VB中的記錄集對象與所使用的數據庫格式及類型是相互獨立的,所以在非Access數據庫中也可以使用數據庫存取對象變量的方法。因而 對FoxPro等外來數據庫而言,使用數據庫存取對象變量的方法同樣也是一種最佳的選擇。 有一點需要注意的是,VB的標準版中僅能使用數據控件(Data Control)對數據庫中的記錄進行訪問,主要的數據庫存取對象中也僅有Database、Dynaset對象可通過數據控件的屬 性提供,其它的重要對象如TableDef、Field、Index、QueryDef、Snapshot、Table等均不能在VB的標準版中生成,所以使用數據存取對象變量的方法只能用VB 3.0以上的專業版。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久一区| 亚洲一品av免费观看| 国内精品久久久久久久久| 日韩视频在线观看免费| 国语对白做受69| 亚洲一区二区久久| 欧美精品成人91久久久久久久| 久久国产一区二区三区| 欧美在线免费观看| 国内精品中文字幕| 亚洲日本中文字幕免费在线不卡| 亚洲色图日韩av| 国产区亚洲区欧美区| 91视频九色网站| 国产91九色视频| 国产精品十八以下禁看| 日韩欧美aⅴ综合网站发布| 国产精品视频在线观看| 色七七影院综合| 日韩电影中文字幕一区| 国产亚洲日本欧美韩国| 欧美午夜www高清视频| 在线观看久久久久久| 色综合色综合久久综合频道88| 欧美情侣性视频| 丝袜美腿亚洲一区二区| www.日韩免费| 亚洲国产精品视频在线观看| 国产精品丝袜高跟| 日韩欧美一区二区三区| 欧美国产日韩一区二区在线观看| 亚洲国产精品99久久| 日韩在线激情视频| 亚洲iv一区二区三区| 日韩av有码在线| 日本中文字幕成人| 国产视频精品自拍| 久久综合伊人77777蜜臀| 精品国产欧美一区二区三区成人| 久久69精品久久久久久久电影好| 精品毛片网大全| 精品视频在线导航| 一本大道香蕉久在线播放29| 丝袜亚洲欧美日韩综合| 欧美大秀在线观看| 日韩中文字幕免费| 91久久久久久久| 欧美电影《睫毛膏》| 91嫩草在线视频| 96精品视频在线| 国产亚洲欧美日韩一区二区| 日韩电影免费在线观看中文字幕| 国模gogo一区二区大胆私拍| 亚洲美女又黄又爽在线观看| 久久久久久亚洲精品| 欧美日韩国产激情| 欧美激情精品久久久久久久变态| 疯狂做受xxxx高潮欧美日本| 欧美精品一区二区三区国产精品| 57pao成人永久免费视频| 国产欧美精品xxxx另类| 欧美午夜精品伦理| 国产日韩在线亚洲字幕中文| 国产午夜精品免费一区二区三区| 亚洲色图13p| 97在线看免费观看视频在线观看| 欧美—级a级欧美特级ar全黄| 国产成人精品av在线| 亚洲国产精彩中文乱码av在线播放| 97人人模人人爽人人喊中文字| 97在线日本国产| 国产一区视频在线| 亚洲国产精品成人va在线观看| 久久福利视频网| 国内精品免费午夜毛片| 欧美性在线视频| 国产欧美在线看| 亚洲天堂男人天堂| 亚洲成人黄色网址| 日韩欧美一区二区三区| 国产成人91久久精品| 国产一区二中文字幕在线看| 国产欧美一区二区三区视频| 亚洲精品videossex少妇| 国产在线播放不卡| 九九热最新视频//这里只有精品| 欧美日韩国产专区| 自拍偷拍亚洲精品| 亚洲成色777777在线观看影院| 成人网址在线观看| 国产精品吊钟奶在线| 亚洲福利精品在线| 欧美贵妇videos办公室| 啪一啪鲁一鲁2019在线视频| 在线视频日本亚洲性| 日韩亚洲在线观看| 国产精品免费看久久久香蕉| 国产成人免费av电影| 在线精品高清中文字幕| 国产精品99久久久久久久久久久久| 国产精品一区久久| 国产精品精品一区二区三区午夜版| 欧美一区亚洲一区| 国产精品高潮呻吟视频| 日本一区二区在线免费播放| 92福利视频午夜1000合集在线观看| 正在播放亚洲1区| 国产一区二区三区在线观看网站| 尤物精品国产第一福利三区| 精品爽片免费看久久| 国产成人精品一区| 欧美寡妇偷汉性猛交| 久久好看免费视频| 国产91精品久久久久久久| 精品久久中文字幕久久av| 欧美精品久久久久久久免费观看| 亚洲色图13p| 欧美成在线视频| 欧美极品美女电影一区| 精品国产一区二区三区久久| 日日狠狠久久偷偷四色综合免费| 国产精品美女免费看| 国产xxx69麻豆国语对白| 亚洲国产私拍精品国模在线观看| 国产精品自产拍高潮在线观看| 日本精品久久久| 在线视频精品一| 欧美大学生性色视频| 国产精品一区二区性色av| 欧美日韩在线看| 国产成人精品亚洲精品| 美日韩丰满少妇在线观看| 欧美夫妻性生活视频| 欧美激情videos| 欧美视频在线观看免费网址| 亚洲乱亚洲乱妇无码| 亚洲精品在线观看www| 中文字幕在线视频日韩| 亚洲国产精品高清久久久| 亚洲丝袜一区在线| 超碰97人人做人人爱少妇| 黄色成人av在线| 日本精品视频在线| 国产精品视频精品| 国产美女主播一区| 影音先锋欧美在线资源| 国产精品高潮呻吟久久av野狼| 日韩中文在线中文网三级| 久久久久久久久国产精品| 久久精品成人欧美大片| 夜夜嗨av色一区二区不卡| 456亚洲影院| 日韩在线视频观看正片免费网站| 国产精品一区二区三| 色中色综合影院手机版在线观看| 91网站在线免费观看| 欧美日韩福利在线观看| 亚洲激情免费观看| 日韩欧美在线视频免费观看| 精品成人乱色一区二区| 欧美激情视频一区| 亚洲一区二区日本| 伊人av综合网| 欧美精品久久一区二区|