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
Sfruttare i tag nell'output cache di ASP.NET Core 7
Workflow di continuous deployment tramite pull request label in GitHub
Sfruttare l'output cache di ASP.NET Core 7 con i controller
Impostare dinamicamente il nome di una run di un workflow di GitHub
Utilizzare flat e flatMap per appiattire array innestati in array
Ottenere il contenuto di una cartella FTP con la libreria FluentFTP
Implementare il throttling in ASP.NET Core
Caricare un asset come parte di una release con un workflow di GitHub
Confronto tra moduli in Javascript: ES e commonJS
Raggruppare i parametri di una minimal API in un singolo oggetto in ASP.NET Core
Sviluppo applicazioni x-plat con .NET MAUI
Ricevere avvisi su metriche dei server Azure Arc
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare i primary constructor in C#
- Installare le Web App site extension tramite una pipeline di Azure DevOps
- tra poco è la volta di #spa, #javascript e #angularjs per lo sviluppatore #aspnet con @sm15455: https://aspit.co/web15-live #aspilive
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- #vs2013, #windowsserver 2012 r2, #sqlserver 2014 e #tfs 2013 annunciati a #msteched. approfondimenti in seguito: https://aspit.co/amo