Per default, EF Core mappa le proprietà di un owned type nella stassa tabella su cui è mappata la classe che contiene l'owned type. Prendiamo il seguente modello che prevede una classe Order e un Owned Type AddressInfo.
public class AddressInfo { public string Address { get; set; } } public class Order { public int Id { get; set; } public ShippingAddress Address { get; set; } public BillingAddress Address { get; set; } }
In questo caso, EF Core si aspetta una tabella Order con i campi Id, ShippingAddress_Address e BillingAddress_Address. Tuttavia possiamo modificare il mapping di default per salvare i dati degli indirizzi in una tabella esterna a quella dell'ordine utilizzando il metodo ToTable subito dopo aver invocato il metodo OwnsOne.
modelBuilder.Entity<Order>().OwnsOne(p => p.BillingAddress).ToTable("OrderAddress"); modelBuilder.Entity<Order>().OwnsOne(p => p.ShippingAddress).ToTable("OrderAddress");
Va sempre ricordato che i dati di un owned type vengono sempre recuperati insieme all'entity principale anche se si trovano in una tabella esterna. Questo significa che quando recuperiamo l'ordine, viene sempre fatta una join verso la tabella degli indirizzi senza necessità di usare il metodo Include.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Estrarre dati randomici da una lista di oggetti in C#
Disabilitare automaticamente un workflow di GitHub
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Creare una libreria CSS universale: Cards
Routing statico e PreRendering in una Blazor Web App
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Utilizzare Azure AI Studio per testare i modelli AI
Generare velocemente pagine CRUD in Blazor con QuickGrid
Potenziare Azure AI Search con la ricerca vettoriale
Gestire la cancellazione di una richiesta in streaming da Blazor