Allo stato attuale (Versione 1.1) Entity Framework core supporta la possibilità di mappare sul database l'ereditarietà tra classi sfruttando il solo pattern Table Per Hierarchy (TPH). Questo pattern prevede che tutti i dati di tutte le classi facenti parti della gerarchia siano memorizzati in una sola tabella e che ci sia una colonna che agisce da discriminatore per specificare a quale classe si riferisce ogni riga del database.
Ad esempio, se abbiamo una classe Person e una classe Employee, le proprietà di queste classi staranno in una tabella chiamata People. Questa tabella conterra una colonna per ogni proprietà delle classi e una colonna Type che specifica se la riga contiene i dati di Person o Employee.
class MyContext : DbContext { public DbSet<Person> People { get; set; } protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity<Person>() .HasDiscriminator<string>("type") .HasValue<Person>("p") .HasValue<Employee>("e"); } } public class Person { public int Id { get; set; } public string Name { get; set; } } public class Employee : Person { public decimal Salary { get; set; } }
Entity Framework fa il detect in automatico della catena di ereditarietà. Con il metodo HasDiscriminator specifichiamo la colonna che agisce da discriminatore, con il metodo HasValue specifichiamo il valore da dare al discriminatore a seconda dell'oggetto che salviamo nella riga.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Eseguire attività basate su eventi con Azure Container Jobs
Autenticarsi in modo sicuro su Azure tramite GitHub Actions
Creare moduli CSS in React
Utilizzare il trigger SQL con le Azure Function
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Eseguire una GroupBy per entity in Entity Framework
Utilizzare le collection expression in C#
Usare Refit e Polly in Blazor per creare client affidabili e fortemente tipizzati
Effettuare lo stream della risposta in ASP.NET Core tramite IAsyncEnumerable
.NET Conference Italia 2023
Implementare l'infinite scroll con QuickGrid in Blazor Server
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON