RefreshMode 枚举 
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
定义 Refresh 方法如何处理开放式并发冲突。
public enum class RefreshModepublic enum RefreshModetype RefreshMode = Public Enum RefreshMode- 继承
字段
| 名称 | 值 | 说明 | 
|---|---|---|
| KeepChanges | 1 | 强制 Refresh 方法保留已更改的当前值,但将其他值更新为数据库值。 | 
| KeepCurrentValues | 0 | 强制 Refresh 方法使用从数据库检索的值替换原始值。 不会修改当前值。 | 
| OverwriteCurrentValues | 2 | 强制 Refresh 方法使用数据库中的值重写所有当前值。 | 
示例
以下示例使用数据库中的值覆盖当前值。
Northwnd db = new Northwnd("...");
try
{
    db.SubmitChanges(ConflictMode.ContinueOnConflict);
}
catch (ChangeConflictException e)
{
    Console.WriteLine(e.Message);
    foreach (ObjectChangeConflict occ in db.ChangeConflicts)
    {
        // All database values overwrite current values.
        occ.Resolve(RefreshMode.OverwriteCurrentValues);
    }
}
Dim db As New Northwnd("...")
Try
    db.SubmitChanges(ConflictMode.ContinueOnConflict)
Catch ex As ChangeConflictException
    Console.WriteLine(ex.Message)
    For Each occ As ObjectChangeConflict In db.ChangeConflicts
        ' All database values overwrite current values.
        occ.Resolve(Data.Linq.RefreshMode.OverwriteCurrentValues)
    Next
End Try
以下示例演示如何将原始值与从数据库检索到的值交换。 不会修改当前值。
try
{
    db.SubmitChanges(ConflictMode.ContinueOnConflict);
}
catch (ChangeConflictException e)
{
    Console.WriteLine(e.Message);
    foreach (ObjectChangeConflict occ in db.ChangeConflicts)
    {
        //No database values are merged into current.
        occ.Resolve(RefreshMode.KeepCurrentValues);
    }
}
Try
    db.SubmitChanges(ConflictMode.ContinueOnConflict)
Catch ex As ChangeConflictException
    Console.WriteLine(ex.Message)
    For Each occ As ObjectChangeConflict In db.ChangeConflicts
        ' No database values are merged into current.
        occ.Resolve(Data.Linq.RefreshMode.KeepCurrentValues)
    Next
End Try
以下示例保留已更改的当前值,但使用数据库值更新其他值。
try
{
    db.SubmitChanges(ConflictMode.ContinueOnConflict);
}
catch (ChangeConflictException e)
{
    Console.WriteLine(e.Message);
    // Automerge database values for members that client
    // has not modified.
    foreach (ObjectChangeConflict occ in db.ChangeConflicts)
    {
        occ.Resolve(RefreshMode.KeepChanges);
    }
}
// Submit succeeds on second try.
db.SubmitChanges(ConflictMode.FailOnFirstConflict);
Try
    db.SubmitChanges(ConflictMode.ContinueOnConflict)
Catch ex As ChangeConflictException
    Console.WriteLine(ex.Message)
    For Each occ As ObjectChangeConflict In db.ChangeConflicts
        ' Automerge database values into current for members
        ' that client has not modified.
        occ.Resolve(Data.Linq.RefreshMode.KeepChanges)
    Next
End Try
' Submit succeeds on second try.
db.SubmitChanges(ConflictMode.FailOnFirstConflict)
注解
此枚举适用于所有 Refresh 重载。