RefreshMode 열거형

정의

Refresh 메서드에서 낙관적 동시성 충돌을 처리하는 방법을 정의합니다.

public enum class RefreshMode
public enum RefreshMode
type RefreshMode = 
Public Enum RefreshMode
상속
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 오버 로드 합니다.

적용 대상