您好,登錄后才能下訂單哦!
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組件,并將它們放在表單上。
2、雙擊表單上的UniConnection1組件。切換到“選項”選項卡,然后將“直接”設置為True。
3、返回到“連接”選項卡,選擇“DBF”作為提供程序,然后輸入計算機上Visual FoxPro(或任何其他xBase數據庫)的路徑。單擊連接。如果一切順利,紅色圓圈將變為綠色。
4、在UniDataSource1中,將DataSet屬性設置為UniQuery1。
5、選擇DBGrid1并將DataSource屬性設置為UniDataSource1。
6、選擇UniQuery1組件并將Connection屬性設置為UniConnection1,然后雙擊該組件并輸入SQL語句。單擊確定。
7、將按鈕的“標題”屬性更改為“在對象檢查器中顯示”。雙擊按鈕,切換到“代碼”選項卡并添加UniQuery1.Open; 到OnClick事件處理程序代碼。
8、按F9編譯并運行您的應用程序。如果程序編譯沒有錯誤,則應該看到已編譯的表單應用程序。單擊顯示以獲取并查看Visual FoxPro表中的數據。
檢索損壞的數據和元數據
xBase方言歷史悠久,.dbf文件中的字段包含不受支持的類型的數據的情況并不罕見。要解決任何不受支持的數據類型的問題,UniDAC提供了兩個選項:IgnoreDataErrors和IgnoreMetaDataErrors。前一個選項在打開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位
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。