MemberChangeConflict.Resolve Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Resolve conflitos de membro mantendo os valores atuais e redefinindo os valores originais da linha de base para que correspondam aos valores mais recentes do banco de dados.
Sobrecargas
Resolve(RefreshMode) |
Usa um parâmetro RefreshMode para especificar automaticamente o valor a ser definido como o valor atual para o membro em conflito. |
Resolve(Object) |
Especifica o valor a ser definido como o valor atual para o membro em conflito. |
Resolve(RefreshMode)
Usa um parâmetro RefreshMode para especificar automaticamente o valor a ser definido como o valor atual para o membro em conflito.
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)
Parâmetros
- refreshMode
- RefreshMode
Consulte RefreshMode.
Exemplos
O exemplo a seguir substitui os valores atuais com valores do banco de dados.
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
O exemplo a seguir mostra como trocar o valor original pelos valores recuperados do banco de dados. Nenhum valor atual é modificado.
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
O exemplo a seguir mantém os valores atuais que foram alterados, mas atualiza os outros valores com valores de banco de dados.
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)
Comentários
Os exemplos a seguir mostram quais resultados são produzidos usando os vários valores para RefreshMode.
Aplica-se a
Resolve(Object)
Especifica o valor a ser definido como o valor atual para o membro em conflito.
public:
void Resolve(System::Object ^ value);
public void Resolve (object value);
member this.Resolve : obj -> unit
Public Sub Resolve (value As Object)
Parâmetros
- value
- Object
O valor a ser definido como o valor atual.
Comentários
O valor definido aqui é o valor a ser usado em uma operação subsequente SubmitChanges .