Entity Framework rappresenta una scelta importante quando si sviluppano applicazioni ASP.NET, perchè la versione 4.0 introduce diverse novità interessanti per lo sviluppatore ASP.NET.
Quello che è importante, quando si vuole utilizzare un'applicazione ASP.NET che abbia un'architettura adeguata, è capire come gestire il ciclo di vita dell'Object Context. La scelta migliore, in tal senso, è quella di sfruttare un approccio che preveda un'istanza per-Request: consente di istanziare e tenere una copia dell'Object Context per richiesta, semplificando le operazioni su più entità all'interno di una richiesta e migliorando anche la scalabilità.
Questo scenario si implementa attraverso un HttpModule di ASP.NET, come ad esempio quello di seguito riportato:
public class WebContextModule : IHttpModule { public void Init(HttpApplication context) { // ad ogni richiesta creiamo un'istanza context.BeginRequest += delegate (object sender, EventArgs e) { HttpContext.Current.Items[ConfigurationKeys.ConnectionString] = new NorthwindEntities(Configuration.ConnectionString); }; // alla fine di ogni richiesta, se attiva, la distruggiamo context.EndRequest += delegate (object sender, EventArgs e) { var ctx = ((ObjectContext) HttpContext.Current.Items[ConfigurationKeys.ConnectionString]); if (ctx != null) ctx.Dispose(); }; } }
Creare un'istanza ad ogni richiesta non aggiunge un overhead significativo, perchè la connessione è aperta fisicamente solo ed esclusivamente nel caso in cui un'operazione (come estrarre o aggiornare/inserire dati) dovesse richiederlo. E' importante, ovviamente, ricordarsi di registrare questo HttpModule all'interno del web.config.
Al fine di semplificare l'accesso all'Object Context, generalmente si preferisce creare una classe di contesto, singleton, che sia in grado di wrappare l'accesso allo stesso. Eccone un esempio:
public sealed class ApplicationContext : IApplicationContext { private static object _sync = new object(); private static volatile ApplicationContext _currentInstance; public static ApplicationContext Current { get { if (_currentInstance == null) { lock (_sync) { if (_currentInstance == null) _currentInstance = new ApplicationContext(); } } return _currentInstance; } } public NorthwindEntities Context { get { if (HttpContext.Current.Items[ConfigurationKeys.ConnectionString] == null) throw new InvalidOperationException( "You must register the HttpModule to use per-Request impelementation."); return ((NorthinwEntities)HttpContext.Current.Items[ ConfigurationKeys.ConnectionString]); } } }
Questa implementazione è molto semplice ed espone direttamente l'Object Context all'applicazione stessa. In caso si volesse disaccoppiare maggiormente Entity Framework dall'applicazione, si può optare per l'utilizzo del pattern Repository.
Approfondimenti
Le novità di Entity Framework 4.0https://www.linqitalia.com/articoli/entity-framework/novita-entity-framework-4.aspx
Utilizzo del pattern Repository con Entity Framework
http://blogs.aspitalia.com/cradle/post2627/Inside-ModelVirtualCasting-Sharp1-Introduzione-Repository.aspx
http://blogs.aspitalia.com/cradle/post2629/Inside-ModelVirtualCasting-Sharp2-Architettura-Interna-Repository.aspx
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Gestire la cancellazione di una richiesta in streaming da Blazor
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Creare gruppi di client per Event Grid MQTT
Criptare la comunicazione con mTLS in Azure Container Apps
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Creare una libreria CSS universale - Rotazione degli elementi
Utilizzare Container Queries nominali
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Generare velocemente pagine CRUD in Blazor con QuickGrid
I più letti di oggi
- Simulare Azure Cosmos DB in locale con Docker
- Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- .NET Conference Italia 2024 - Milano
- .NET Conference Italia 2023 - Milano e Online