#104 - Persistere un grafo complesso di oggetti sul database con Entity Framework
Molto spesso capita di dover persistere un oggetto che ha altri oggetti collegati. Un tipico caso di questa situazione è quando si deve salvare un ordine sul database. Un ordine ha collegati sia i dettagli, sia il cliente che lo ha generato. Una serie di oggeti del genere viene definita grafo.
In Entity Framework persistere un grafo non è immediato in quanto esiste la regola secondo la quale se si aggiunge un oggetto al contesto per poi inserirlo nel database (tramite il metodo Add dell'ObjectContext), tutte le entità collegate vengono automaticamente aggiunte al contesto in stato di Added e quindi pronte per essere inserite sul database.
Per i dettagli dell'ordine la cosa non è un problema, ma per il cliente si in quanto non deve essere nuovamente inserito.
Per questo motivo bisogna prima fare l'Attach del cliente al contesto e poi associarlo all'ordine. In questo modo, il cliente viene aggiunto al contesto in stato di Unchanged e quindi non verrà fatta alcune operazione su di esso nel database.
Order o = new Order { Id = 1, Address = "via dei platani 14", ZipCode = "00100", City = "Rome" }; Customer c = new Customer { CustomerId = 1 }; using (var ctx = new DBContext()) { ctx.AddToOrder(o); ctx.AttachTo("Customers", c); o.Customer = c; ctx.SaveChanges(); }
Approfondimenti
-
Entity Framework e la generazione di codice POCO
-
#124 - Ottimizzare le Where con l'operatore Like in Entity Framework
-
Architettura del software: l'object model per le applicazioni web
-
#109 - Effettuare il Binding in WPF di una query Entity Framework
-
Utilizzare Entity SQL per eseguire query in Entity Framework
-
#107 - Passare un Expression di Entity Framework attraverso un servizio WCF
-
#146 - Simulare la clausola SQL Exists con il metodo Any in LINQ to Entities
-
#111 - Personalizzare la serializzazione delle entità di ADO.NET Data Services
-
Real Code Day 4.0: costruire applicazioni reali - Firenze
-
Basta! Italia 2009 - I'll be there!
-
#98 - Mapping dell'ereditarietà con Table-Per-Type in Entity Framework
-
.NET Framework 4.0 Beta 1: Parallel FX

















Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.