Procedura: aprire manualmente la connessione dal contesto dell'oggetto (Entity Framework)
In questo argomento viene fornito un esempio di apertura manuale di una connessione dal contesto dell'oggetto.
L'esempio incluso in questo argomento è basato sul modello descritto in Modello Sales di AdventureWorks. Per eseguire il codice incluso in questo esempio, è necessario avere già aggiunto il modello Sales di AdventureWorks al progetto e avere configurato il progetto per l'utilizzo di Entity Framework. A tale scopo, completare la procedura descritta in Procedura: utilizzare la procedura guidata Entity Data Model (Entity Framework).
Esempio
In questo esempio viene aperta la connessione manualmente, quindi viene eseguita una query e vengono salvate le modifiche. La connessione è chiusa quando il contesto è esterno all'ambito ed è stato eliminato.
' Define the order ID for the order we want.
Dim orderId As Integer = 43680
Using context As New AdventureWorksEntities()
' Explicitly open the connection.
context.Connection.Open()
' Execute a query to return an order.
Dim order As SalesOrderHeader = context.SalesOrderHeaders.Where("it.SalesOrderID = @orderId", _
New ObjectParameter("orderId", orderId)).Execute(MergeOption.AppendOnly).First()
' Change the status of the order.
order.Status = 1
' Save changes.
If 0 < context.SaveChanges() Then
Console.WriteLine("Changes saved.")
End If
' The connection is closed when the object context
' is disposed because it is no longer in scope.
End Using
// Define the order ID for the order we want.
int orderId = 43680;
using (AdventureWorksEntities context =
new AdventureWorksEntities())
{
// Explicitly open the connection.
context.Connection.Open();
// Execute a query to return an order.
SalesOrderHeader order =
context.SalesOrderHeaders.Where(
"it.SalesOrderID = @orderId", new ObjectParameter("orderId", orderId))
.Execute(MergeOption.AppendOnly).First();
// Change the status of the order.
order.Status = 1;
// Save changes.
if (0 < context.SaveChanges())
{
Console.WriteLine("Changes saved.");
}
// The connection is closed when the object context
// is disposed because it is no longer in scope.
}
Vedere anche
Attività
Procedura: gestire la connessione in un contesto dell'oggetto con esecuzione prolungata (Entity Framework)
Procedura: utilizzare EntityConnection con un contesto dell'oggetto (Entity Framework)