Capita spesso di avere nel database una tabella con gli utenti all'interno della quale c'è una colonna (foto) VarBinary che contiene l'avatar o la foto dell'utente. Quando mappiamo questa tabella con Entity Framework, la colonna viene mappata verso una proprietà di tipo byte[] che rappresenta la foto. Ogni volta che eseguiamo una query, la foto viene recuperata e messo nella proprietà mappata. Questo comportamento non è ottimale perchè nella maggior parte dei casi non abbiamo bisogno di recuperare la foto ad ogni query e quindi sprechiamo risorse.
Entity Framework non supprta il lazy loading di una proprietà che non sia una proprietà di navigazione, quindi per fare in modo che la foto venga caricata solo se richiesta, dobbiamo trasformare la foto in una proprietà di navigazione utilizando la tecnica del Table-Splitting che prevede che una tabella sia mappata su più classi. Cominciamo col definire le classi.
public class UserPhoto { public int Id { get; set; } public byte[] Contract { get; set; } public User User { get; set; } } public class User { public int Id { get; set; } public string Name { get; set; } public UserPhoto Photo { get; set; } }
Una volta che abbiamo definito le classi, dobbiamo mapparle sul database verso una sola tabella. possiamo raggiungere questo scopo grazie alle API di Code-First nel seguente modo.
public class SVCContext : DbContext { public DbSet<User> Users { get; set; } protected override void OnModelCreating(DbModelBuilder modelBuilder) { base.OnModelCreating(modelBuilder); modelBuilder.Entity<User>().ToTable("Companies"); modelBuilder.Entity<UserPhoto>().ToTable("Companies"); modelBuilder.Entity<User>() .HasRequired(p => p.UserPhoto) .WithRequiredPrincipal(p => p.User); } }
Grazie al metodo ToTable, le classi sono mappate su una sola tabella mentre con i metodi HasRequired e WithRequiredPrincipal viene stabilita la relazione.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Generare una User Delegation SAS in .NET per Azure Blob Storage
Ordine e importanza per @layer in CSS
.NET Aspire per applicazioni distribuite
Usare le navigation property in QuickGrid di Blazor
Creare una libreria CSS universale: Cards
Fissare una versione dell'agent nelle pipeline di Azure DevOps
Rendere le variabili read-only in una pipeline di Azure DevOps
Change tracking e composition in Entity Framework
Generare velocemente pagine CRUD in Blazor con QuickGrid
Generare la software bill of material (SBOM) in GitHub
Eseguire i worklow di GitHub su runner potenziati
Migliorare l'organizzazione delle risorse con Azure Policy
I più letti di oggi
- .NET Conference Italia 2024 - Milano
- Develop and distribute Azure Functions using K8s and CI/CD
- Disponibile la versione finale di Hyper-V: la virtualizzazione per Windows Server 2008
- Speciale Mastering Entity Framework
- Velocity arriva alla CTP3
- Silverlight Summer: un'estate speciale piena di Style per i controlli Silverlight!
- Disponibile la versione beta di Silverlight 4.0
- Mono 0.13: ora anche web services
- .NET Alerts Software Development Kit