方法 : 複製挿入クエリを作成する
複製挿入クエリを使用すると、テーブル間またはテーブル内で行をコピーできます。たとえば、titles テーブルで複製挿入クエリを使用すると、特定の出版社のすべての書名に関する情報を別のテーブルにコピーして、その出版社に提供できます。複製挿入クエリは、テーブル作成クエリと似ていますが、既存のテーブルに行をコピーする点が異なります。
ヒント |
---|
テーブル間の行のコピーは、カット アンド ペーストを使用して行うこともできます。各テーブルのクエリを作成して、クエリを実行します。必要な行を結果グリッドから別の結果グリッドにコピーします。 |
複製挿入クエリを作成するときは、次の項目を指定します。
行のコピー先のデータベース テーブル (コピー先テーブル)。
行のコピー元として使用するテーブル (コピー元テーブル)。コピー元テーブルはサブクエリの一部となります。テーブル内にコピーする場合、コピー元とコピー先は同じテーブルです。
内容をコピーするコピー元テーブルの列。
データのコピー先となるコピー先テーブルの列。
コピーする行を定義する検索条件。
行を特定の順序でコピーする場合は、並べ替え順序。
集計情報だけをコピーする場合は、[グループ化] オプション。
たとえば、次のクエリでは、titles テーブルの書名情報を archivetitles というアーカイブ テーブルにコピーします。このクエリでは、特定の出版社のすべての書名に関する 4 つの列の内容をコピーします。
INSERT INTO archivetitles
(title_id, title, type, pub_id)
SELECT title_id, title, type, pub_id
FROM titles
WHERE (pub_id = '0766')
[!メモ]
新しい行に値を挿入するには、値挿入クエリを使用します。
行の特定の列の内容をコピーする方法と、行のすべての列の内容をコピーする方法があります。どちらの方法でも、コピー元のデータには、コピー先の行の列との互換性が必要です。たとえば、price などの列の内容をコピーする場合、コピー先の行の列には、小数点を含む数値データを入力できる必要があります。行全体をコピーする場合、コピー先テーブルには、互換性のある列がコピー元テーブルと同じ順序で存在することが必要です。
複製挿入クエリを作成すると、データのコピーに使用できるオプションが抽出条件ペインに表示されます。また、データのコピー先となる列を指定できるように、[追加] 列が追加されます。
注意 |
---|
複製挿入クエリの実行アクションを元に戻すことはできません。念のため、クエリを実行する前にデータをバックアップしてください。 |
[!メモ]
お使いのマシンで、Visual Studio ユーザー インターフェイスの一部の要素の名前や場所が、次の手順とは異なる場合があります。これらの要素は、使用している Visual Studio のエディションや独自の設定によって決まります。詳細については、「Visual Studio の設定」を参照してください。
複製挿入クエリを作成するには
新しいクエリを作成して、行のコピー元となるテーブル (ソース テーブル) を追加します。テーブル内で行をコピーする場合は、コピー先テーブルと同じコピー元テーブルを追加します。
[クエリ デザイナー] メニューの [クエリ タイプの変更] をポイントし、[結果の挿入] をクリックします。
[挿入先のテーブル選択] ダイアログ ボックスで、行のコピー先となるテーブル (コピー先テーブル) を選択します。
[!メモ]
クエリ デザイナーおよびビュー デザイナーは、更新できるテーブルおよびビューを事前に判別できません。そのため、[挿入先のテーブル選択] ダイアログ ボックスの [挿入先] ボックスには、クエリを実行するデータ接続で使用できるテーブルおよびビューがすべて表示されます。行をコピーできないテーブルおよびビューも表示されます。
テーブルまたはテーブル値オブジェクトを示す四角形で、内容をコピーする列の名前を選択します。すべての行をコピーする場合は、[* (すべての列)] を選択します。
選択した列が、抽出条件ペインの [列] 列に追加されます。
抽出条件ペインの [追加] 列で、コピーする各列に対してコピー先テーブルの目的の列を選択します。すべての行をコピーする場合は、tablename.* を選択します。コピー先テーブルの列は、コピー元テーブルの列と同じデータ型か、互換性のあるデータ型である必要があります。
特定の順序で行をコピーする場合は、並べ替え順序を指定します。詳細については、「クエリ結果の並べ替えおよびグループ化」を参照してください。
コピーする行を指定するために、[フィルター] 列に検索条件を入力します。詳細については、「方法 : 検索条件を指定する」を参照してください。
検索条件を指定しない場合は、コピー元テーブルのすべての行がコピー先テーブルにコピーされます。
[!メモ]
検索する列を抽出条件ペインに追加すると、コピーする列の一覧にその列も追加されます。検索に使用する列をコピーしない場合は、テーブルまたはテーブル値オブジェクトを示す四角形内の列名の横のチェック ボックスをオフにします。
集計情報をコピーする場合は、[グループ化] オプションを指定します。詳細については、「クエリ結果の集計」を参照してください。
複製挿入クエリを実行しても、結果ペインには結果が表示されません。代わりに、コピーされた行数を示すメッセージが表示されます。