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 les conflits de membres en conservant les valeurs actuelles et en réinitialisant les valeurs d’origine de la base de référence pour qu’elles correspondent aux valeurs de base de données les plus récentes.
Surcharges
| Nom | Description |
|---|---|
| Resolve(RefreshMode) |
Utilise un RefreshMode paramètre pour spécifier automatiquement la valeur à définir comme valeur actuelle pour le membre en conflit. |
| Resolve(Object) |
Spécifie la valeur à définir comme valeur actuelle pour le membre en conflit. |
Resolve(RefreshMode)
Utilise un RefreshMode paramètre pour spécifier automatiquement la valeur à définir comme 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
Voir RefreshMode.
Exemples
L’exemple suivant remplace les valeurs actuelles avec des 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 échanger 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 des 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 comme 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 comme valeur actuelle.
Remarques
La valeur définie ici est la valeur à utiliser dans une opération ultérieure SubmitChanges .