同步方向无法按预期工作

时间:2013-02-14 06:32:13

标签: c# microsoft-sync-framework

我有一个使用Microsoft Sync Framework的项目。除了同步方向外,一切正常。如果是上传或下载,我会根据用户的选择设置Synch Orchestrator的同步方向。

编辑:

我上传了一份文件以更好地解释这种情况:

google doc link

代码:

private void RunSynch()
{
    SqlConnection sqlServer = new SqlConnection(GetServerConnectionString());
    SqlConnection sqlClient = new SqlConnection(GetClientConnectionString());

    SyncOrchestrator syncOrchestrator = new SyncOrchestrator();
    syncOrchestrator.LocalProvider = new SqlSyncProvider(strScopeName, sqlClient);
    syncOrchestrator.RemoteProvider = new SqlSyncProvider(strScopeName, sqlServer); 

    switch(iButtonState) // int constant
    {
        case STATE_UPLOAD:

            syncOrchestrator.Direction = SyncDirectionOrder.Upload;
            break;

        case STATE_DOWNLOAD:

            syncOrchestrator.Direction = SyncDirectionOrder.Download;
            break;
    }

    ((SqlSyncProvider)syncOrchestrator.RemoteProvider).ApplyChangeFailed += new EventHandler<DbApplyChangeFailedEventArgs>(RemoteProvider_ApplyChangeFailed);
    ((SqlSyncProvider)syncOrchestrator.LocalProvider).ApplyChangeFailed += new EventHandler<DbApplyChangeFailedEventArgs>(LocalProvider_ApplyChangeFailed);

    syncStats = syncOrchestrator.Synchronize();
}



private void RemoteProvider_ApplyChangeFailed(object sender, DbApplyChangeFailedEventArgs e)
{

    if (rdoConflict.SelectedIndex == 0)// server wins option
    {
        e.Action = ApplyAction.Continue;
    }
    else
    {
        e.Action = ApplyAction.RetryWithForceWrite;
    }
}

private void LocalProvider_ApplyChangeFailed(object sender, DbApplyChangeFailedEventArgs e)
{
    if (rdoConflict.SelectedIndex == 0) // server wins option
    {
        e.Action = ApplyAction.RetryWithForceWrite;
    }
    else
    {
        e.Action = ApplyAction.Continue;
    }
}

这里的问题是服务器数据库会被客户端更改更新,即使同步方向只是下载。

修正:

我现在终于开始工作了。同步框架完全没有问题,但它是指定Direction的开关部分,我进行了调试,发现程序没有经过切换情况,这就是为什么方向始终是双向的。

1 个答案:

答案 0 :(得分:1)

我终于得到了理由:

首次同步数据库时会发生什么。

如果它们都有不同的数据,则所有行都会发生冲突。

如果发生冲突,默认情况下服务器总是会赢(也可以将其更改为远程胜利)

所以所有的更改都来自遥控器,那就是你想知道Sync Framework是错误的。

原因:

稍后当服务器获胜时,通过更改远程和中央数据库发生一些冲突

更新:

您的提供商使用此:

localProvider.ApplyChangeFailed += new EventHandler<DbApplyChangeFailedEventArgs>(LocalProvider_ApplyChangeFailed);
remoteProvider.ApplyChangeFailed += new EventHandler<DbApplyChangeFailedEventArgs>(RemoteProvider_ApplyChangeFailed);


private void LocalProvider_ApplyChangeFailed(object sender, DbApplyChangeFailedEventArgs e)
    {


     // Need to right your conditions like 
        e.Action = ApplyAction.Continue;

    }