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
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Keynote .NET Conference Italia 2025
Integrare modelli AI in un workflow di GitHub
Recuperare le subissue e il loro stato di completamento in GitHub
Utilizzare ExecuteUpdate per aggiornare colonne JSON in Entity Framework
Gestire trasferimenti cloud con Azure Storage Mover
Integrazione di Copilot in .NET Aspire
Fornire parametri ad un Web component HTML
Effettuare un clone parziale di un repository di GitHub
Importare un servizio esterno in .NET Aspire
Gestione dei prompt file a livello di organizzazione aziendale in GitHub
Come automatizzare il download dei report di billing da GitHub Enterprise




