削除と挿入のペアとして UPDATE ステートメントがレプリケートされる可能性があります。

重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。

英語版 KB:238254
概要
場合は、unique 制約の一部であるすべての列SQL Server「遅延更新」は、更新プログラムを実装し、、更新されますが一対の手段 削除/挿入 操作します。この「遅延更新」が送信するレプリケーションが発生する1 組 削除/挿入 サブスクライバーへのステートメント。その他の状況もいます。遅延更新を可能性があります。したがって、ビジネス ロジックは、実装、 更新プログラム トリガーまたはカスタム ストアド プロシージャをサブスクライバー側で必要があります。含め、 削除/挿入 トリガーまたはカスタム ストアド プロシージャを使用します。
詳細
既定の動作では、トランザクション レプリケーションを使用すること 挿入, 更新プログラム削除 カスタムのストアドの手順で変更を適用するのには、サブスクライバー。

挿入 ステートメントをパブリッシャーでサブスクライバーに適用されています。を通じて、 挿入 ストアド プロシージャの呼び出し。同様に、 削除 ステートメントを適用します。 削除 ストアド プロシージャの呼び出し。

ただし、場合は、 更新プログラム ステートメント「遅延更新として」は、ログ リーダー エージェントが実行されます。ペアを配置します。 削除/挿入 ストアド プロシージャ コールをディストリビューション データベースに適用するには更新ではなく、サブスクライバーにストアド プロシージャの呼び出し。たとえば、TABLE1、これら 3 つの列の名前、公開のテーブルがあるとします。
  • int 型の値
  • col2 int
  • col3 varchar(30)。
一意の制約を"テーブル 1"col1 で定義されています。主キー制約します。1 つのレコードがあること前提としています。(1, 1、'ダラス')。

このコードを実行するとします。
UPDATE TABLE1 set col1 = 3 where col2 = 'Dallas'				
は、 更新プログラム ステートメントが SQL Server でのペアとして実装されます。 削除/挿入 一意なインデックスを持つ列 1 を更新するためのステートメント定義されています。したがってのペアをログリーダーを配置します。 削除/挿入 ディストリビューション データベースに呼び出されます。これは、ビジネスに影響を与えることができます。カスタム ストアド プロシージャで、トリガーが存在するロジックは、サブスクライバー。内の追加のビジネス ロジックを組み込む必要があります。 削除挿入 トリガーまたはストアド プロシージャがこのような状況を処理します。

1 つのロジックを使用して必要なすべてを 更新プログラム として複製コマンド 削除/挿入 ペアは、トレース フラグ Microsoft ではこの手順に従ってできます。サポート技術情報の記事:
160181 INF: 更新プログラムの削除と挿入のペアとしてレプリケートするトレース フラグ
さらに、水平方向を使用する場合文書内でのフィルターと、更新された行は、フィルターを満たしていないかどうか条件は、 削除 プロシージャ ・ コールは、サブスクライバーに送信されます。場合は、更新された行以前、フィルターの条件を満たしていませんでしたが、条件を満たす、更新は、 挿入 プロシージャの呼び出し、レプリケーション ・ プロセスに送信されます。

上記の例でも水平があったと想定します。table1 という名前で定義されているフィルター:、col2 'ダラス' =。このコードを実行するとします。
UPDATE table1 set col2 = 'New York' where col1 = 3				
ログ リーダー エージェントにのみ配置します。 削除 ストアド プロシージャの呼び出し後、サブスクライバーに適用するのには、更新された行は、水平方向のフィルター条件を満たしていません。

ここで場合は、このコードを実行します。
UPDATE table1 set col2 = 'Dallas' where col1 = 3				
だけに、ログリーダーが生成されます、 挿入 行いない以前に対応しなかったので、ストアド プロシージャの呼び出しは、条件にフィルターを適用します。

が、 更新プログラム パブリッシャー側でのみ適切な操作が実行されます。コマンドをサブスクライバーに適用されます。
関連情報
SQL Server 2000 Service Pack 1 またはそれ以降を参照してください、以下の資料は、マイクロソフト サポート技術。
302341 INF: トランザクション レプリケーションのシングルトンの更新を有効にする新しいトレース フラグ

警告: この記事は自動翻訳されています

プロパティ

文書番号:238254 - 最終更新日: 07/13/2011 19:41:00 - リビジョン: 8.0

  • kbinfo kbmt KB238254 KbMtja
フィードバック