文書番号: 180841 - 最終更新日: 2011年9月22日 - リビジョン: 4.0

Jet データベース エンジンの一般的な SQL のデータ定義言語 (DDL) ステートメントを使用する方法

お知らせお使いのオペレーティング システムには適用しない情報が含まれている場合があります。

目次

すべて展開する | すべて折りたたむ

概要

この資料でいくつかの一般的な DDL (データ定義を示しています。Microsoft Jet データベース エンジンの言語) SQL のステートメント。

詳細

Microsoft Jet データ定義の完全なセットが用意されています言語 SQL ステートメントを作成するために使用できる、変更、および削除テーブル、インデックス、および Microsoft Access データベース ファイルの関係。行うことができます。この DDL は、Access データベースを操作するために、MFC データベース クラスの使用を使用します。このカテゴリの SQL ステートメントの一般的な例を掲載しています。

この資料では、1 つの DDL ステートメントを実行できます、MFC DAO クラスで次の構文:
   // Open database file.
   CDaoDatabase db;
   db.Open( _T("C:\\MyDatabase.mdb") );

   // Set strSQL to desired DDL statement.
   CString strSQL;
   strSQL = _T("CREATE TABLE Simple (ID long)" );

   // Execute DDL statement.
   try
   {
      db.Execute( strSQL, dbFailOnError );
   }
   catch ( CDaoException *e )
   {
      // Display errors (simple example).
      AfxMessageBox( e->m_pErrorInfo->m_strDescription,
                     MB_ICONEXCLAMATION );
      e->Delete();
   }
				
この記事では、次を使用して、DDL ステートメントを実行できます。MFC ODBC クラスの構文:
   // Open database file.
   CDatabase db;
   db.OpenEx( _T("DSN=MyAccessDB"), CDatabase::noOdbcDialog );

   // Set strSQL to desired DDL statement.
   CString strSQL;
   strSQL = _T("CREATE TABLE Simple (ID long)" );

   // Execute DDL statement.
   try
   {
      db.ExecuteSQL( strSQL );
   }
   catch ( CDBException *e )
   {
      // Display errors (simple example).
      AfxMessageBox( e->m_strError,
                     MB_ICONEXCLAMATION );
      e->Delete();
   }
				

CREATE テーブルの DDL ステートメント

次の create table ステートメントをテスト テーブルを作成します。Microsoft Access のデータ型に使用できる DDL のすべて。
   CREATE TABLE TestAllTypes
   (

      MyText       TEXT(50),
      MyMemo       MEMO,
      MyByte       BYTE,
      MyInteger    INTEGER,
      MyLong       LONG,
      MyAutoNumber COUNTER,
      MySingle     SINGLE,
      MyDouble     DOUBLE,
      MyCurrency   CURRENCY,
      MyReplicaID  GUID,
      MyDateTime   DATETIME,
      MyYesNo      YESNO,
      MyOleObject  LONGBINARY,
      MyBinary     BINARY(50)
    )
				
メモ「オート ナンバー型レプリケーション」「ハイパーリンク」を作成できません: または「参照」型のフィールドは、Microsoft Access の DDL SQL ステートメントを使用して。これらのフィールド型ネイティブの Jet フィールド型ではありませんし、作成およびだけが使用される、Microsoft Access のユーザー インターフェイスです。上記の MyBinary フィールドに特別なのです。Access では作成できません固定長バイナリ フィールドユーザー インターフェイスしますが、SQL の DDL ステートメントを使用して作成できます。

行うことができます。テーブルに単一フィールド主キーを持つ 1 つの DDL ステートメントを作成します。は、次のステートメントは、主キーを持つ TestPrimaryKey をという名前のテーブルを作成します。PK_MyID という名前の MyID フィールド。
   CREATE TABLE TestPrimaryKey
   (
      MyID LONG CONSTRAINT PK_MyID PRIMARY KEY,
      FirstName TEXT(20),
      LastName  TEXT(20)
   )
				

ALTER TABLE の DDL ステートメント

Microsoft Access の DDL は、テーブルの ALTER DDL ステートメントをサポートしています。これステートメントは削除するか、既存にフィールドを追加する必要がある場合に便利です。テーブルです。

メモ: 次のステートメントで既存のフィールドを変更することはできませんがAccess テーブルなフィールドのデータ型を変更するなど)。

は、次の DDL 詳細情報は、テーブルから TooManyFields という名前の列を削除します。
   ALTER TABLE TooManyFields DROP COLUMN MoreInfo
				
以下の DDL ステートメント テーブルに引数 ExtraInfo をという名前の列を追加します。NotEnoughFields を名前します。
   ALTER TABLE NotEnoughFields ADD COLUMN ExtraInfo Text(255)
				
リレーションシップを作成するのには、ALTER TABLE ステートメントも使用できます。2 つのテーブル間。

次の SQL 文が 2 つのテーブルを作成します。(車および色) し、車のテーブル間にリレーションシップを作成し、色テーブルな ColorID フィールド (各車は 1 つだけ持つことができます。色) です。

メモ: が実行する必要があります 3 つ別 DDL ステートメントです。一度に 1 つずつ。
   CREATE TABLE Cars
   (
      CarID LONG,
      CarName TEXT(50),
      ColorID LONG
   )

   CREATE TABLE Colors
   (
      ColorID LONG CONSTRAINT PK_Colors PRIMARY KEY,
      ColorName TEXT(50)
   )


   ALTER TABLE Cars
   ADD CONSTRAINT MyColorIDRelationship
   FOREIGN KEY (ColorID) REFERENCES Colors (ColorID)
				
メモ「連鎖更新」または「重ねて表示ように指定することはできません"は DDL を使用して作成されたリレーションシップを削除します。これらの機能が利用可能です。Microsoft DAO を使用する場合 (データ アクセス オブジェクト) がコードでインターフェイスのみやMicrosoft Access のユーザー インターフェイスを使用する場合。

CREATE INDEX DDL ステートメント

作成するインデックス DDL ステートメントを使用して作成するには既存のテーブルのインデックス。

以下の DDL ステートメントを追加します。MyStateIndex フィールドに単一フィールド、一意ではなく、昇順のインデックスの名前内のテーブルのアドレス。
   CREATE INDEX MyStateIndex
   ON Addresses
   (
      State ASC
   )
				
次の DDL 文は、2 つのフィールド、一意、昇順のインデックスが追加されます。名前フィールドと姓フィールド テーブルに名前付き MyFullNameIndexアドレス:
   CREATE UNIQUE INDEX MyFullNameIndex
   ON Addresses
   (
      FirstName ASC,
      LastName  ASC
   )
				
NULL を許可しない] を使用して制約を指定することもできます。作成テーブル DDL ステートメント。NULL を許可しない] を指定するインデックスをつまり列に null 値を持つフィールドの挿入を防ぐ内のインデックス。

次の DDL ステートメントでは、単一フィールド作成します。一意、降順のインデックス MySalaryIndex 給与テーブル内のフィールドの名前HRInfo:
   CREATE UNIQUE INDEX MySalaryIndex
   ON HRInfo
   (
      Salary DESC
   )
   WITH DISALLOW NULL
				
すべてのレコード値の給料がこのインデックスが適用されます。フィールドです。

ドロップ DDL ステートメント

DDL の DROP ステートメントを使用して既存のテーブルを削除するかインデックスです。

以下の DDL ステートメントがテーブルを永久に削除されます。TempTable の名前。
   DROP TABLE TempTable
				
指定したインデックスは、次の DDL ステートメントが完全に削除されます。OverIndexedTable を MyUnusedIndex。
   DROP INDEX MyUnusedIndex ON OverIndexedTable
				

関連情報

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