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 2 Next »

The conflict "Command affected 0 row(s)" is the most common type of conflict that can occur with replication. This conflict can be on a delete or update statement.

This conflict indicates that the data is no longer in sync between the source and target data. 

This conflict can have the following causes in order of most likely:

  1. The data was not 100% insync when replication started
  2. A previous conflict was ignored and so the data is now out of sync
  3. The data was independently manipulated on the target database
  4. There are uncommitted transactions on the apply database. Please see Uncommitted transactions

The first step is to determine where the data is different between the source and target. For example which column is different.

To view the SQL causing the conflict see https://dbvisit.atlassian.net/wiki/display/ugdr/Viewing+the+conflicts

In order to determine where the difference is, the conflicting SQL can be manually run on the target database. The process is to run it repeatedly each time removing 1 predicate.
For example if the conflicting SQL is:

 

DELETE from SCOTT."REQUESTS" 
where (1=1)
and ID = 3567
and TYPE IS NULL
and VERSION = 4
and STATE IS NULL
and STATUS = 'A'
and STATUSLASTMODIFIED = to_timestamp('2013.08.23 17:39:38.788000000', 'yyyy.mm.dd hh24:mi:ss.ff')
and NAMESPACEID = 1
and ISRELATIVE IS NULL
and RELATIVEBASEDATE = 3
and ACCEPTEDDATETIME = to_timestamp('2013.08.23 17:39:38.000000000', 'yyyy.mm.dd hh24:mi:ss.ff')
Error: Command affected 0 row(s). 
Handled as: RETRY 
Conflict repeated 11789 times.

 

Then this query can be turned into a SELECT statement that can be run manually on the target database:

SELECT * from SCOTT."REQUESTS" 
where (1=1)
and ID = 3567
and TYPE IS NULL
and VERSION = 4
and STATE IS NULL
and STATUS = 'A'
and STATUSLASTMODIFIED = to_timestamp('2013.08.23 17:39:38.788000000', 'yyyy.mm.dd hh24:mi:ss.ff')
and NAMESPACEID = 1
and ISRELATIVE IS NULL
and RELATIVEBASEDATE = 3
and ACCEPTEDDATETIME = to_timestamp('2013.08.23 17:39:38.000000000', 'yyyy.mm.dd hh24:mi:ss.ff')
;

This query will also return 0 rows when it is run on the target as it has the same conditions as the delete statement which caused the conflict. 

Now remove the last predicate in the where clause and run again. In the case "and ACCEPTEDDATETIME" is removed:

SELECT * from SCOTT."REQUESTS" 
where (1=1)
and ID = 3567
and TYPE IS NULL
and VERSION = 4
and STATE IS NULL
and STATUS = 'A'
and STATUSLASTMODIFIED = to_timestamp('2013.08.23 17:39:38.788000000', 'yyyy.mm.dd hh24:mi:ss.ff')
and NAMESPACEID = 1
and ISRELATIVE IS NULL
and RELATIVEBASEDATE = 3
;

If this now returns a record on the target database, then the data conflict is due to predicate that has just been removed. In this case "ACCEPTEDDATETIME"

If this still returns 0 rows, then remove the next predicate and run again.

Repeat this process until the select statement returns data. 

The next step is to determine why the data is different. Compare the same row on source and target to determine what the difference is. Is it due to:

  1. The data not being in sync before the replication started?
  2. Someone else changed the data on the target?
  3. Open transactions on the target database. Please see Uncommitted transactions

Once it is understood why the conflict occurs, then conflict can be /wiki/spaces/UGDREP/pages/15761558.

If the data divergence is too great and it is not possible to resolve iit through the conflict, then the table should be manually resynched. Please see http://support.dbvisit.com/entries/24422248-Synching-up-one-table-when-it-gets-out-of-sync

  • No labels