処理でDDLが評価される仕組み
Oracle GoldenGateパラメータの異なる基準が処理される順序、およびExtractとReplicatがそれぞれDDLを処理する方法の違いについて学習します。
Extract
-
Extractは、DDL文をキャプチャします。
-
Extractは、コメントがあれば、メインの文から分離します。
-
Extractは、
DDLパラメータを検索します。(この例では、存在するものとします。) -
Extractは、
IGNOREREPLICATESパラメータを検索します。これがあり、ReplicatがこのシステムでこのDDLを生成した場合、ExtractはそのDDL文を無視します。(この例では、このシステムではReplicat操作がないものとします。) -
Extractは、DDL文が
RENAMEかどうかを判断します。そうである場合、名前変更に内部的にフラグが付けられます。 -
Extractにより、ベース・オブジェクト名と導出オブジェクト名(存在する場合)が取得されます。
-
文が
RENAMEの場合、ExtractはこれをALTER TABLE RENAMEに変更します。 -
Extractは、
DDLOPTIONS REMOVECOMMENTS BEFOREパラメータを検索します。これがある場合、ExtractはDDL文からコメントを削除しますが、INSTRまたはINSTRCOMMENTSを使用するDDL INCLUDEまたはDDL EXCLUDEに備えてコメントを格納します。 -
ExtractはDDLのスコープ(
MAPPED、UNMAPPEDまたはOTHER)を判断します。-
操作とオブジェクト・タイプがマッピングに対してサポートされており、ベース・オブジェクト名や導出オブジェクト名(
RENAMEの場合)がTABLEパラメータに含まれている場合、MAPPEDです。
-
操作とオブジェクト・タイプがマッピングに対してサポートされておらず、ベース・オブジェクト名や導出オブジェクト名(
RENAMEの場合)がTABLEパラメータに含まれていない場合、UNMAPPEDです。 -
これ以外の場合、操作は
OTHERと識別されます。
-
-
Extractは、
DDLパラメータにINCLUDE句とEXCLUDE句があるかどうかをチェックし、これらの句のDDLパラメータ基準を評価します。INCLUDEまたはEXCLUDEがTRUEと評価されるには、すべてのオプションがTRUEと評価される必要があります。次のようになります。-
EXCLUDE句がTRUEと評価される場合、ExtractはDDL文を破棄し、別のDDL文を評価します。この場合、処理のステップが最初から始まります。 -
INCLUDE句がTRUEと評価される場合、またはDDLパラメータにINCLUDE句もEXCLUDE句も含まれていない場合、ExtractはDDL操作を含めて、処理ロジックが続けられます。
-
-
Extractは、
DDLSUBSTパラメータを検索し、INCLUDE句およびEXCLUDE句を評価します。それらの句の基準が最終的にTRUEになる場合、Extractは文字列の置換を行います。Extractは、パラメータ・ファイル内の各DDLSUBSTパラメータに対してDDL文を評価します。すべてのtrueのDDLSUBST指定について、DDLSUBSTパラメータがファイル内にリストされている順に、Extractによって文字列の置換が行われます。 -
DDLSUBTが処理されたため、ExtractはREMOVECOMMENTS AFTERパラメータを検索します。これがある場合、ExtractはDDL文からコメントを削除します。 -
Extractは、
DDLOPTIONS ADDTRANDATAを検索します。これがある場合、操作がCREATE TABLEであれば、ExtractはALTER TABLEnameADD SUPPLEMENTAL LOG GROUPコマンドを表に対して発行します。 -
Extractにより、DDL文が証跡に書き込まれます。