Using a Row ID to Identify a Record (Oracle)
For transaction-based replications (mirroring and synchronization), it is critical to be able to uniquely identify records in the source and target databases, before performing UPDATE and DELETE operations during replication. Database applications typically make use of primary keys to uniquely identify records.
Syniti Replicate can use primary keys that have been previously set in the source and target databases to identify records during replication. It is also possible to create primary keys within the Syniti Replicate environment for use only during replications with Syniti Replicate. If, however, you are replicating from Oracle and you do not have a primary key set on the source table, you can use the Oracle Row ID to identify records during replication.
To use the Row ID to identify each record:
-
In the target table, create an additional column of type String.
-
If you have not yet created the replication, when you get to the Set Mapping Info screen of the Replication wizard or Multiple Replications wizard, choose to map the newly created column to an expression.
If you have created the replication, in the Replication Properties dialog, open the Fields Mapping dialog and choose to map the newly created column to an expression. -
In the Expression Generator, expand the tree to display the Values node.
-
Expand the Values node to display Log Field values.
-
Select the !RecordID value.
The !RecordID value represents the Oracle Row ID. -
Click OK in the Expression Generator.
You have now set the value of the column that you created above to the Oracle Row ID.
Any time you reorganize a source table (to compress deleted rows, etc.), Syniti Replicate needs to perform a full refresh of all the target tables mapped using the Row ID.
Related Topics
Define Primary Key Dialog
Primary Key Settings for Mirroring and Synchronization