@RANGE
ファンクションでは、表の行を複数のOracle GoldenGateプロセス間に分割します。サイズが大きく頻繁にアクセスされる表のスループットを向上させるためや、異なる宛先に配布するデータを分割するためにも使用できます。各範囲は、TABLE
文またはMAP
文のFILTER
句で指定します。
@RANGE
は、安全で拡張性あるファンクションです。同一の行が常に同一のプロセス・グループに処理されることを保証することにより、データの整合性を維持します。行が別のプロセス・グループにパーティションを移行しないように、また、DMLが正しい順序で実行されるように、@RANGE
パーティショニングが基盤とする列は、プロセスの実行中に一切変更することはできません。パーティション列を更新すると、行が見つからないというエラーまたは一意制約エラーが発生する可能性があります。
@RANGE
は、入力で指定された列のハッシュ値を計算します。列が指定されない場合、TABLE
またはMAP
文にKEYCOLS
句が指定されていれば、KEYCOLS
句を使用して、ハッシュする列を確認します。それ以外の場合は、主キー列を使用します。
Oracle GoldenGateは、指定された範囲数で均等に分散できるように、合計範囲数を調整します。
このファンクションには任意の列を指定できるため、相互に関係制約を持つ表の行は、参照整合性を維持するために、同一のプロセスまたはトレイルにグループ化する必要があります。
注意: 範囲は、Extractを使用して計算するほうが、Replicatを使用するよりも効率的です。ターゲット側で範囲を計算するには、Replicatがトレイル全体を読取り、各範囲の指定を満たすデータを見つける必要があります。 |
構文
@RANGE (range, total_ranges [, column] [, column] [, ...])
range
指定のプロセスまたはトレイルに割り当てる範囲。total_ranges
で定義する値を最大値として、
1
、2、3
のように指定します。
total_ranges
割り当てる範囲の合計数。たとえば、データを3つのグループに分割するには、値3
を使用します。
column
範囲割当ての基準にする列名。この引数はオプションです。使用されない場合、Oracle GoldenGateは表の主キーに基づいて範囲を割り当てます。
例
次の例では、レプリケーション・ワークロードは、ソース表acct
のID
列に基づいて、3つの範囲(3つのReplicatプロセス間)に分割されます。
(Replicatグループ1のパラメータ・ファイル)
MAP sales.acct, TARGET sales.acct, FILTER (@RANGE (1, 3, ID));
(Replicatグループ2のパラメータ・ファイル)
MAP sales.acct, TARGET sales.acct, FILTER (@RANGE (2, 3, ID));
(Replicatグループ3のパラメータ・ファイル)
MAP sales.acct, TARGET sales.acct, FILTER (@RANGE (3, 3, ID));
次の例では、1つのExtractプロセスが処理ロードを2つのトレイルに分割します。範囲計算の基準にする列が定義されていないため、Oracle GoldenGateは主キー列を使用します。
RMTTRAIL /ggs/dirdat/aa TABLE fin.account, FILTER (@RANGE (1, 2)); RMTTRAIL /ggs/dirdat/bb TABLE fin.account, FILTER (@RANGE (2, 2));
次の例では、2つの表でorder_ID
列に基づく関連操作が行われます。order_master
表は、キーorder_ID
を持ち、order_detail
表は、キーorder_ID
およびitem_number
を持ちます。キーorder_ID
によって関係が確立されるため、参照整合性を維持するために、両方の表の@RANGE
フィルタでこのキーが使用されます。ロードは2つの範囲に分割されます。
(パラメータ・ファイル#1)
MAP sales.order_master, TARGET sales.order_master, FILTER (@RANGE (1, 2, order_ID)); MAP sales.order_detail, TARGET sales.order_detail, FILTER (@RANGE (1, 2, order_ID));
(パラメータ・ファイル#2)
MAP sales.order_master, TARGET sales.order_master, FILTER (@RANGE (2, 2, order_ID)); MAP sales.order_detail, TARGET sales.order_detail, FILTER (@RANGE (2, 2, order_ID));