Uno dei limiti principali di EF (e di altri O/RM) è quello di non permettere l'esecuzione di più comandi in contemporanea pena il sollevamento di un'eccezione.
Esistono tuttavia molti casi in cui eseguire query in simultanea è necessario per ottimizzare le prestazioni. Pensiamo ad una dashboard dove ogni box è popolato con dati provenienti da una query diversa. In questi casi poter eseguire le query in contemporanea ottimizza parecchio le prestazioni rispetto a un'esecuzione sequenziale delle query.
Non potendo superare la limitazione di EF, dobbiamo ricorrere a un altra tecnica per eseguire le query: creare più istanze del contesto. Quando ci troviamo in una situazione dove il contesto viene passato nel costruttore, questa soluzione non sembra praticabile. Tuttavia, possiamo fare una cosa diversa: iniettare IServiceProvider e tramite questo creare uno scope di dependency injection per ogni contesto da usare. In questo modo avremo tanti contesti quante le query e ognuno può eseguire una query in contemporanea.
public class Manager(IServiceProvider sp) { public async Task ExecuteQueries() { var tasks = new Task[2]; using var s1 = sp.CreateScope(); using var s2 = sp.CreateScope(); var ctx1 = s1.ServiceProvider.GetRequiredService<MyContext>(); var ctx2 = s2.ServiceProvider.GetRequiredService<MyContext>(); tasks[0] = ctx1.People.Where(c => c.Cognome.StartsWith("A")).ToListAsync(); tasks[1] = ctx2.People.Where(c => c.Age < 18).ToListAsync(); await Task.WhenAll(tasks); //process results } }
Con questa tecnica, il codice da scrivere aumenta notevolmente rispetto a un approccio sequenziale. Per questo motivo, se ne suggerisce l'uso solo li dove effettivamente le performance siano una necessità irrinunciabile.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Gestione file Javascript in Blazor con .NET 9
Combinare Container Queries e Media Queries
Ottimizzare le pull con Artifact Cache di Azure Container Registry
Change tracking e composition in Entity Framework
Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
Configurare e gestire sidecar container in Azure App Service
Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
Generare una User Delegation SAS in .NET per Azure Blob Storage
Migliorare l'organizzazione delle risorse con Azure Policy
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub