C++ での ADOX を使用して新しい Jet 4.0 形式のデータベースに、古い Jet データベース ファイルをコピーする方法

文書翻訳 文書翻訳
文書番号: 321328
この資料は、アーカイブされました。これは "現状のまま" で提供され、更新されることはありません。
すべて展開する | すべて折りたたむ

概要

この資料では、データ定義言語とセキュリティ (ADOX) Visual C では、古い形式の Jet データベースからデータを使用して新しい Jet データベースを作成するのには、ActiveX データ オブジェクトの拡張機能を使用する方法を示します。この資料は、ADOX では、Visual C で使用される、次の方法も示します。
  • Visual C での ADOX を使用して Jet データベースを作成する方法
  • データベース内のテーブルの一覧を取得する方法
  • 列の型など、テーブルのメタデータを取得する方法
  • 使用する方法を 追加 テーブルおよび列を作成するのには、ADOX メソッド
  • Jet OLE DB プロバイダー固有のプロパティを使用してリンク テーブルを作成する方法
  • データベース間でデータをコピーするのには、ADOX と組み合わせて ADO を使用する方法
  • Jet データベースからテーブルを削除する方法

詳細

テストは、 CompactDatabase Jet レプリケーション オブジェクト (JRO) のメソッドがわかりますこのメソッドでは使用できません efectively テーブル Jet 4.0 形式変換を場合は、基になるテーブルを Access 2.0 または Access 95 形式です。Access 2.0 または Access 95 で生成されたテーブルを Jet 4.0 形式に変換するか、 CompactDatabase JRO オブジェクトを Access 2000 または Access 2002 のメソッドが正常にデータベースを開くことができません。この問題は、microsoft の調査でです。JRO オブジェクトの目的は Jet 4.0 および Jet 3.5 では x の形式のデータベースを操作することに注意してください。

古い Jet データベースよりも古い Jet 3.5 インチ形式) に変換するには、ADOX を使用して 4.0 形式のデータベースを新規作成し、すべてのテーブルをコピーします。これを行う方法の例を次に示します。これは単純な例で、主キー、インデックス、プロパティ、および関係などのいくつかの特殊なシナリオに対処していません。サンプルのみテーブルをコピーし、ソース データベースから他のオブジェクトはコピーされません。方法の詳細については、MSDN ライブラリの Web サイトでを参照してください。

C++ プロジェクトでは、次のコードを保存し、プロジェクトをビルドします。

メモ#Import と接続文字列のパス以外のコードで何も変更はありません。
#import "c:\Program Files\Common Files\system\ado\msado15.dll" 
#import "c:\Program Files\Common Files\system\ado\msadox.dll"

#include <iostream>
using namespace std;

void main()
{
	
   CoInitialize(NULL);
	
   //ADO Connection Object pointers for source and destination.
   ADODB::_ConnectionPtr SourceCon = NULL;
   ADODB::_ConnectionPtr DestCon = NULL;

   //ADOX Catalog object pointers for source and destination.
   ADOX::_CatalogPtr DestDB = NULL;
   ADOX::_CatalogPtr SourceDB = NULL;
	
   //Connection string. 
   _bstr_t SrcConnectionString(L""), DestConnectionString(L""), SourceDBLocation(L"");

   ADOX::_TablePtr linkedTbl = NULL;
   ADOX::_ColumnPtr f = NULL;
   ADOX::_TablePtr DestTable = NULL;

   try{

         SourceDBLocation = (L"C:\\JET30FormatDB.mdb");
         //Per Q299484, you must use ODBC Provider to avoid alphabetical ordering.
         SrcConnectionString = "Driver={Microsoft Access Driver (*.mdb)};"
			"DBQ=" + SourceDBLocation; 

         DestConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;"
			  "Data Source=C:\\JET40FormatDB.mdb;"	;

         SourceCon.CreateInstance(__uuidof(ADODB::Connection));
         SourceCon->Open(SrcConnectionString,"","",-1);
         SourceDB.CreateInstance(__uuidof (ADOX::Catalog));
         //ADOX catalog must have an active ADO connection 
         SourceDB->PutActiveConnection(_variant_t((IDispatch *) SourceCon));
		
         DestDB.CreateInstance(__uuidof (ADOX::Catalog));
		
         //This line creates a Jet database, and throws an exception if it already exists.
         DestDB->Create(DestConnectionString);
         DestCon.CreateInstance(__uuidof(ADODB::Connection));
         DestCon->Open(DestConnectionString,"","",-1);
         DestDB->PutActiveConnection(_variant_t((IDispatch *) DestCon));

         //Get the count of tables in Source Database.
         long x = SourceDB->Tables->Count;
         for (int i = 0; i < x ; i++)
         {
            // Go through each table that is listed as TABLE and not SYSTEM TABLE or ACCESS SYSTEM TABLE.
            if (SourceDB->Tables->Item[(long)i]->Type == _bstr_t(L"TABLE"))
            {
               cout<<"Now copying "<< (LPCSTR)SourceDB->Tables->Item[(long)i]->Name<<endl;
               _bstr_t tblName = SourceDB->Tables->Item[(long)i]->Name;
               //Start creating a table.
               DestTable.CreateInstance(__uuidof(ADOX::Table));
               DestTable->Name = tblName;

               //Get number of columns in Source Table. 
               int cnt = SourceDB->Tables->Item[tblName]->Columns->Count;
				
               //Use ADOX Append method to append all columns to the destination table. 
               for ( int col = 0; col < cnt; col++)
               {
                  f = SourceDB->Tables->Item[tblName]->Columns->Item[(long)col];
                 DestTable->Columns->Append(f->Name,f->Type,f->DefinedSize);
               }
					
               //Finally, append destination table.
               DestDB->Tables->Append( DestTable.GetInterfacePtr());

               //This step is to get the data from source table. 
               //Create a temporary linked table in Destination Database
               //and run "Insert Into mynewTable Select * from LinkedTable".
               linkedTbl.CreateInstance(__uuidof(ADOX::Table));
               linkedTbl->ParentCatalog = DestDB;
               linkedTbl->Name = "TempLink2";
               linkedTbl->Properties->Item["Jet OLEDB:Create Link"]->Value = (long)true;
               linkedTbl->Properties->Item["Jet OLEDB:Link Datasource"]->Value = SourceDBLocation;      
               linkedTbl->Properties->Item["Jet OLEDB:Remote Table Name"]->Value = tblName;
				DestDB->Tables->Append(linkedTbl.GetInterfacePtr());

               DestCon->Execute("Insert into " + tblName + " Select * From TempLink2", NULL, -1);
               //You do not have to keep this linked table around, so you can delete it. 
               DestDB->Tables->Delete("TempLink2");
               DestTable.Release();
               linkedTbl.Release();
            }
            else
            {
               cout <<"Skipping "<< (LPCSTR)SourceDB->Tables->Item[(long)i]->Name <<endl;
            }
			
        } // End of for loop.
				
        DestCon->Close();
        SourceCon->Close();
       }
       catch(_com_error &e)
       {
         _bstr_t bstrSource(e.Source());
         _bstr_t bstrDescription(e.Description());
         cout<< "Source: "<< (LPCSTR)bstrSource <<"\nDescription : " << (LPCSTR)bstrDescription <<endl;
       }
}
				

関連情報

詳細については、MSDN Library で、次のマイクロソフト Web サイトを参照してください。
http://msdn2.microsoft.com/en-us/library/default.aspx
MSDN ライブラリの左側のペインで [内容] ツリーで、次のヘルプ トピックを参照してください。
  \Data Access
    \Microsoft Data Access Components
      \ADO
        \SDK Documentation
          \Microsoft ActiveX Data Objects (ADO)
            \ADO Programmer's Guide
				
詳細については、マイクロソフト サポート技術記事を表示するのには以下の記事番号をクリックしてください。
225048 情報: ADO と Jet を Jet の DAO の移行に関する問題
304322 ACC2002 リレーションをインポートするには、ADOX の使用方法
230588 ADOX を使用して Jet テーブルのリンク、および更新する方法のリンク
279245 修正: ADOX に Access データベースを使用して値を確認または設定すると列の既定のプロパティをクリアします。
304323 [ACC2002] ADOX を使用して、SQL のパススルー クエリを作成する方法
275252 Acc 2000: で Jet データ型によっては、ADOX のテーブルを作成する方法
252908 ADOX で主キーを持つテーブルを作成するには、方法
230501 ADO 経由で Access データベースを最適化するには、方法

プロパティ

文書番号: 321328 - 最終更新日: 2014年2月26日 - リビジョン: 3.0
キーワード:?
kbnosurvey kbarchive kbhowto kbfile kbmt KB321328 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:321328
Microsoft Knowledge Base の免責: Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。

フィードバック

 

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