Partager via


MemberChangeConflict.Resolve Méthode

Définition

Résout des conflits entre membres en conservant les valeurs actuelles et en réinitialisant les valeurs d'origine de base pour qu'elles correspondent aux valeurs les plus récentes de la base de données.

Surcharges

Resolve(RefreshMode)

Utilise un paramètre RefreshMode pour spécifier automatiquement la valeur à définir en tant que valeur actuelle pour le membre en conflit.

Resolve(Object)

Spécifie la valeur à définir en tant que valeur actuelle pour le membre en conflit.

Resolve(RefreshMode)

Utilise un paramètre RefreshMode pour spécifier automatiquement la valeur à définir en tant que valeur actuelle pour le membre en conflit.

public:
 void Resolve(System::Data::Linq::RefreshMode refreshMode);
public void Resolve (System.Data.Linq.RefreshMode refreshMode);
member this.Resolve : System.Data.Linq.RefreshMode -> unit
Public Sub Resolve (refreshMode As RefreshMode)

Paramètres

refreshMode
RefreshMode

Consultez RefreshMode.

Exemples

L’exemple suivant remplace les valeurs actuelles par les valeurs de la base de données.

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

L’exemple suivant montre comment permuter la valeur d’origine avec les valeurs récupérées à partir de la base de données. Aucune valeur actuelle n'est modifiée.

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

L’exemple suivant conserve les valeurs actuelles qui ont été modifiées, mais met à jour les autres valeurs avec les valeurs de base de données.

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)

Remarques

Les exemples suivants montrent les résultats générés à l’aide des différentes valeurs pour RefreshMode.

S’applique à

Resolve(Object)

Spécifie la valeur à définir en tant que valeur actuelle pour le membre en conflit.

public:
 void Resolve(System::Object ^ value);
public void Resolve (object value);
member this.Resolve : obj -> unit
Public Sub Resolve (value As Object)

Paramètres

value
Object

Valeur à définir en tant que valeur actuelle.

Remarques

La valeur définie ici est la valeur à utiliser dans une opération ultérieure SubmitChanges .

S’applique à