我有一个使用Microsoft Sync Framework的项目。除了同步方向外,一切正常。如果是上传或下载,我会根据用户的选择设置Synch Orchestrator的同步方向。
编辑:
我上传了一份文件以更好地解释这种情况:
代码:
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的开关部分,我进行了调试,发现程序没有经过切换情况,这就是为什么方向始终是双向的。
答案 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;
}