Quando eseguiamo una query tramite Entity Framework, spesso abbiamo l'esigenza di recuperare dati da più entity. Grazie all'espressività di LINQ to Entities e al metodo Include, mettere in relazione più entity è estremamente semplice. Tuttavia quando le entity coinvolte nella query sono tante, la query SQL che viene inviata al database diventa pesante.
In scenari come questi, si possono ottimizzare le prestazioni limitando l'uso della clausola Include ed effettuando più query. L'ovvio svantaggio di questa tecnica è quello di dover eseguire più query, ma spesso questo svantaggio è superato dai vantaggi.
Facciamo un esempio. Supponiamo di dover eseguire una query che estrae gli ordini con i relativi dettagli, il cliente che ha piazzato l'ordine, il dipendente che lo ha inserito e i prodotti presenti nei dettagli. Eseguire in un colpo solo una query simile significa mettere in JOIN molte tabelle sul database il che significa bassa velocità di esecuzione e, soprattutto, un'enorme mole di dati duplicati restituiti dalla query il che aumenta il carico di rete ed il tempo che Entity Framework impiega per trasformari i dati nel database in oggetti.
Se suddividiamo la query in query più piccole otteniamo una maggior velocità di esecuzione ed un minore numero di dati scambiati tra il database e la nostra applicazione. La cosa più importante è che Entity Framework mette comunque in relazione le entity recuperate. Il risultato è che alla fine delle query, gli ordini sono collegati ai clienti, al dipendente, ai dettagli e ai prodotti esattamente come se i dati fossero stati recuperati in una sola query.
Ovviamente, come tutte le ottimizzazioni, questa tecnica non è da applicare sempre; il suo utilizzo va valutato caso per caso misurando le prestazioni sul campo.
//Query lenta var orders = ctx.Orders.Include(o => o.Customer).Include(o => o.Employee).Include(o => o.Details.Select(d => d.Product)); //Ottimizzata ctx.Customers.Load(); ctx.Employees.Load(); var orders = ctx.Orders.Include(o => o.Details.Select(d => d.Product));
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Testare il failover sulle region in Azure Storage
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Selettore CSS :has() e i suoi casi d'uso avanzati
Supportare la crittografia di ASP.NET Core con Azure Container App
Eseguire una ricerca avanzata per recuperare le issue di GitHub
Creare una libreria CSS universale: i bottoni
Proteggere le risorse Azure con private link e private endpoints
Loggare le query più lente con Entity Framework
Gestione dei nomi con le regole @layer in CSS
Utilizzare Containers in .NET Aspire
Fornire parametri ad un Web component HTML
I più letti di oggi
- Disponibile la release finale di Moonlight 1.0
- domani su @aspitalia troverete un articolo speciale dedicato a Windows Phone 8: non ... https://aspit.co/wp-summit #WPSummit
- vuoi costruire applicazioni web in real time? non perdere il nostro speciale! https://aspit.co/aln #signalr #websockets #polling #aspnet
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Utilizzare l'access modifier private protected in C# 7.2