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(); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Loggare le query più lente con Entity Framework
Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
Generare velocemente pagine CRUD in Blazor con QuickGrid
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Utilizzare il metodo ExceptBy per eseguire operazione di sottrazione tra liste
Change tracking e composition in Entity Framework
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Filtrare i dati di una QuickGrid in Blazor con una drop down list
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare il pattern matching per semplificare le espressioni
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare requestAnimationFrame per animazioni fluide
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!