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
Registrare servizi multipli tramite chiavi in ASP.NET Core 8
Gestire domini wildcard in Azure Container Apps
Implementare il throttling in ASP.NET Core
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON
Gestire il colore CSS con HWB
Creare form tipizzati con Angular
Gestire undefined e partial nelle reactive forms di Angular
Eseguire una query su SQL Azure tramite un workflow di GitHub
Utilizzare il trigger SQL con le Azure Function
Assegnare un valore di default a un parametro di una lambda in C#
Utilizzare le collection expression in C#
Gestire liste di tipi semplici con Entity Framework Core