Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 4 Next »

You can create a PL/SQL function to handle a particular conflict. The following command set 'nodata_update_avi' function to be executed when there s 'NO_DATA' conflict 

raised by Dbvisit Replicate for update operation on scott.avi table.

 

SET_CONFLICT_HANDLERS FOR TABLE scott.avi FOR UPDATE ON NO_DATA TO PLSQL scott.dbvisit.nodata_update_avi

The function must have following prototype:

 

function_name(apply_old_data table%rowtype, has_found_apply_row boolean, primary_key_data table%rowtype, new_data table%rowtype) return number;

Here,

apply_old_data : the values at the target, queried by using key columns in the where clause. The boolean flag indicates whether any such record was found.

primary_key_data: old values at the source; mostly used to see the key, but it actually contains all supplementally logged values, too. Thus it will always (excl. LOBs, LONGs) include the modified column, too.

new_data: new (modified) values at the source.

The return values are:

  • 0: Discard
  • 1: Overwrite
  • 2: Retry
  • 3: The PL/SQL function resolved the conflict by itself and made all necessary changes.
  • 4: Force

The function must not issue a commit, as the transaction may be yet rolled back, if a rollback happened on source.

See also Data available to apply sessions for further information available to the handler.

 

It is not possible to pass modified values back to apply. If you are not satisfied with the return value options (discard, retry, newer, older), you have to apply the change yourself.

  • No labels