MemberChangeConflict.Resolve Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
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 .