如何壓縮透過 ADO 來的 Microsoft Access 資料庫

文章翻譯 文章翻譯
文章編號: 230501
本文曾發行於 CHT230501
全部展開 | 全部摺疊

在此頁中

結論

雖然 ADO 規格並沒有提供壓縮 Microsoft Access 資料庫中的物件,可以使用 ADO 延伸來達成這項功能: Microsoft Jet OLE DB 提供者和複寫的物件 (JRO)。這項功能是用來實作 JET OLE DB 提供者版本 4.0 (Msjetoledb40.dll) 和 JRO 2.1 (Msjro.dll) 版中的第一次。在安裝的 MDAC 2.1 後就有這些 DLL 檔案。您可以下載最新版的 MDAC,從下列網站:
通用資料存取的網站

其他相關資訊

若要壓縮 Access 資料庫中使用 ADO 時,MDAC 2.1 (含) 以後必須適當地安裝在電腦上。若要壓縮 Microsoft Access 資料庫中使用 Visual Basic 和 Visual c + + 的主要步驟如下:

Visual Basic: 壓縮的 Access 資料庫透過 ADO

  1. 在 Visual Basic IDE 中,在 [專案] 功能表上按一下 [參考]。
  2. 新增Microsoft Jet 及複寫物件 X.X 文件庫,其中 (x.x 上是大於或等於 2.1)。
  3. Visual Basic,取代資料來源與目的資料庫路徑,如有需要,加入以下程式碼行:
    Dim jro As jro.JetEngine
    Set jro = New jro.JetEngine
    jro.CompactDatabase "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\nwind2.mdb;Jet OLEDB:Database Password=test", _ 
    "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\abbc2.mdb;Jet OLEDB:Engine Type=4;Jet OLEDB:Database Password=test"
    					
附註:在 DAO 3.60 RepairDatabase 方法已無法使用。上述程式碼會顯示 CompactDatabase 方法的使用。這個方法會取代 DAO 3.5 RepairDatabase 方法。

Visual c + +: 壓縮的 Access 資料庫透過 ADO

  1. 除了 # import,Msado15.dll (MDAC2.1),新增下列 # import 陳述式至您的.cpp 類別 JRO 產生包裝函式類別 (或者,您可以產生包裝函式類別更有效率地使用 # import 的前置處理器陳述式的 no_implementation 和 implementation_only 屬性):
    #import "C:\PROGRAM FILES\COMMON FILES\System\ado\MSJRO.DLL" no_namespace 
    					
  2. 將下列加入 (指定您自己的來源與目的資料庫路徑) 至您想要用來壓縮資料庫的.cpp 檔:
    ...
    try
    {
       IJetEnginePtr jet(__uuidof(JetEngine));
      jet->CompactDatabase( "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\nwind2.mdb;Jet OLEDB:Database Password=test", 
    "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\\abbc.mdb;" \ 
    "Jet OLEDB:Engine Type=4;Jet OLEDB:Database Password=test");
    }
    catch(_com_error &e) 
    {       
       ::MessageBox(NULL, (LPCTSTR)e.Description( ), "", MB_OK) ;    
    }
    					
附註:Jet OLEDB:Engine 型別 = 4 是僅供 Jet 3.x 格式 MDB 檔案。如果這個值遺漏了,資料庫會自動升級為 4.0 版本 (Jet OLEDB:Engine 類型 = 5)。Jet OLEDB:Engine 型別,請參閱下表中的適當值:
摺疊此表格展開此表格
Jet OLEDB:Engine 型別Jet x.x 格式 MDB 檔案
1JET10
2JET11
3JET2X
4JET3X
5JET4X

?考

如需詳細資訊,請參閱下列「 Microsoft 知識庫文件:
230496 透過 OLE DB 壓縮的 Microsoft Access 資料庫

屬性

文章編號: 230501 - 上次校閱: 2012年5月16日 - 版次: 1.0
關鍵字:?
kbhowto kbjet kbprovider kbmt KB230501 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:230501
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。
依現狀不再更新的知識庫內容免責聲明
本文旨在說明 Microsoft 不再提供支援的產品。因此,本文係依「現狀」提供,不會再更新。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com