如何在Delphi中訪問DBF數據庫

xBase是所有源自原始dBase數據庫格式(.dbf)的數據庫的通用術語。該列表包括Visual FoxPro、Clipper、dBase III、dBase IV等。這些數據庫被非正式地稱爲dBase克隆,因爲它們是dBase的直接後代或模仿者。

xBase數據庫將大量格式化數據以結構化形式存儲在.dbf數據文件中。在類似dBase的數據庫中,.dbf文件存儲一個表,其中保留了表描述,字段描述符和記錄。類似dBase的現代數據庫還具有用於大型文本字段(備忘錄)、命令、過程、備份等的文件。

有各種各樣的數據庫引擎可以讀取和操作DBF文件中的數據,但是它們都不瞭解xBase數據庫的所有格式——這些數據庫引擎中的大多數都可以與xBase系列的一種或兩種方言進行交互。與其他現有解決方案不同,UniDAC中的Delphi數據訪問提供程序TDBFUniProvider提供了一種引擎,該引擎可以理解許多類似dBase的數據庫中的DBF文件。

UniDAC是一款通用數據庫訪問組件,提供了多個數據庫的直接訪問,如針對Windows的Delphi, C++Builder, Lazarus (以及 Free Pascal) , Mac OS X, iOS, Android, Linux和64和32位的FreeBSD等等。

TDBFUniProvider提供對xBase數據庫的直接訪問,並支持所有dBase本機數據類型(字符、數字、邏輯、數據、備忘錄)。它用作SQL引擎,對數據庫文件執行命令。項目中的Delphi代碼被編譯成可執行文件,不需要任何其他外部文件即可訪問和操作DBF文件中的數據。

用於訪問xBase數據庫文件的UniDAC Delphi組件支持多種數據庫文件格式:dBase III、dBase IV、dBase V、dBase VII、FoxPro2、Visual FoxPro、Clipper、CodeBase、HiPer-Six。除了允許開發人員使用標準的SQL-92語法外,它還提供了一種快速的方法來重建表並刪除已刪除的記錄,以減小數據庫文件的大小。

創建示例Delphi應用程序以訪問xBase數據庫

我們將創建一個簡單的Delphi應用程序,該應用程序將以Visual FoxPro格式連接到數據庫,並在單擊“顯示”按鈕時顯示錶中的記錄。

1、在“工具選項板”中找到TUniConnection、TUniQuery、TUniDataSource、TDBFUniProvider、TDBGrid和TButton組件,並將它們放在表單上。

UniDAC使用教程:如何在Delphi中訪問DBF數據庫

2、雙擊表單上的UniConnection1組件。切換到“選項”選項卡,然後將“直接”設置爲True。

UniDAC使用教程:如何在Delphi中訪問DBF數據庫

3、返回到“連接”選項卡,選擇“DBF”作爲提供程序,然後輸入計算機上Visual FoxPro(或任何其他xBase數據庫)的路徑。單擊連接。如果一切順利,紅色圓圈將變爲綠色。

UniDAC使用教程:如何在Delphi中訪問DBF數據庫

4、在UniDataSource1中,將DataSet屬性設置爲UniQuery1。

UniDAC使用教程:如何在Delphi中訪問DBF數據庫

5、選擇DBGrid1並將DataSource屬性設置爲UniDataSource1。

UniDAC使用教程:如何在Delphi中訪問DBF數據庫

6、選擇UniQuery1組件並將Connection屬性設置爲UniConnection1,然後雙擊該組件並輸入SQL語句。單擊確定。

UniDAC使用教程:如何在Delphi中訪問DBF數據庫

7、將按鈕的“標題”屬性更改爲“在對象檢查器中顯示”。雙擊按鈕,切換到“代碼”選項卡並添加UniQuery1.Open; 到OnClick事件處理程序代碼。

55dbf_delphi_onclick2.png

8、按F9編譯並運行您的應用程序。如果程序編譯沒有錯誤,則應該看到已編譯的表單應用程序。單擊顯示以獲取並查看Visual FoxPro表中的數據。

UniDAC使用教程:如何在Delphi中訪問DBF數據庫

檢索損壞的數據和元數據

xBase方言歷史悠久,.dbf文件中的字段包含不受支持的類型的數據的情況並不罕見。要解決任何不受支持的數據類型的問題,UniDAC提供了兩個選項:IgnoreDataErrorsIgnoreMetaDataErrors。前一個選項在打開DBF表時強制UniDAC忽略損壞的數據錯誤,而後一個選項使UniDAC忽略元數據錯誤:當兩個選項都設置爲True時,將跳過損壞的數據,並正確地檢索其他數據。

另一個功能是當您不完全瞭解DBF文件的格式時(DBFFormat選項中的dfAuto值),可以自動確定xBase數據庫的方言。

支持的目標平臺

UniDAC支持多個目標平臺:您可以創建一個訪問DBF數據庫的應用程序,用於:

  • Windows,32位和64位

  • macOS,32位和64位

  • iOS,32位和64位

  • Android,32位和64位

  • Linux,32位和64位


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章