DataContext.GetChangeSet Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Faz com que os objetos modificados sejam rastreados por DataContext.
public:
System::Data::Linq::ChangeSet ^ GetChangeSet();
public System.Data.Linq.ChangeSet GetChangeSet();
member this.GetChangeSet : unit -> System.Data.Linq.ChangeSet
Public Function GetChangeSet () As ChangeSet
Devoluções
O conjunto de objetos é devolvido como três coleções apenas de leitura.
Exemplos
Northwnd db = new Northwnd(@"c:\northwnd.mdf");
var custQuery =
from cust in db.Customers
where cust.City == "London"
select cust;
foreach (Customer custObj in custQuery)
{
Console.WriteLine("CustomerID: {0}", custObj.CustomerID);
Console.WriteLine("\tOriginal value: {0}", custObj.City);
custObj.City = "Paris";
Console.WriteLine("\tUpdated value: {0}", custObj.City);
}
ChangeSet cs = db.GetChangeSet();
Console.Write("Total changes: {0}", cs);
// Freeze the console window.
Console.ReadLine();
db.SubmitChanges();
Dim db As New Northwnd("c:\northwnd.mdf")
Dim custQuery = _
From cust In db.Customers _
Where (cust.City = "London") _
Select cust
For Each custObj As Customer In custQuery
Console.WriteLine("CustomerID: {0}", custObj.CustomerID)
Console.WriteLine(vbTab & "Original value: {0}", custObj.City)
custObj.City = "Paris"
Console.WriteLine(vbTab & "Updated value: {0}", custObj.City)
Next
Dim cs As ChangeSet = db.GetChangeSet()
Console.Write("Total changes: {0}", cs)
' Freeze the console window.
Console.ReadLine()
db.SubmitChanges()
Observações
Observe as seguintes considerações:
GetChangeSet podem ter efeitos secundários, como inferência de operações de inserção e eliminação que normalmente são realizadas no momento de SubmitChanges. Por exemplo, objetos usados nas seguintes operações podem criar operações inferidas correspondentes na seguinte lista:
Add para InsertOnSubmit.
EntityRef<TEntity> atribuição a null (possivelmente por causa de Remove a DeleteOnSubmit.
O conjunto pode não ser ordenado de acordo com restrições de chave estrangeira.
Os valores gerados pela base de dados (por exemplo, valores de chave primária e estrangeira, carimbos temporais, etc.) não estão disponíveis. Tal informação requer execução de comandos na base de dados e talvez a propagação da informação recuperada (por exemplo, chave estrangeira da chave primária).
O conjunto de objetos alterados é calculado no momento da chamada. Chamadas subsequentes podem SubmitChanges produzir um conjunto diferente se forem feitas alterações adicionais.
A saída quando não foram feitas alterações aparece da seguinte forma:
{Added: 0, Removed: 0, Modified: 0}