Molto spesso capita di dover fare query complesse che richiedono join tra molte tabelle. Sebbene LINQ faccia un ottimo lavoro per rendere semplice la scrittura di queste query, ci sono casi in cui l'estrema complessità rende il codice poco leggibile e anche poco performante. In questi casi, una buona soluzione può essere quella di spezzare la query in due o più query più piccole e lasciare che sia Entity Framework a ricomporre i pezzi per noi.
Supponiamo di avere un modollo dove un cliente può piazzare ordini. Ogni ordine ha più dettaglio e per ogni dettaglio abbiamo un prodotto che è preso da un fornitore. Se volessimo fare una query che gli ordini, il cliente, i dettagli con il prodotto associato e il relativo fornitore, dovremmo scrivere una query molto complessa e soprattutto poco performante. Scrivere tutto in una query LINQ e usare il metodo AsSplitQuery può aiutare, ma non è sempre efficace soprattutto quando la query è complessa e vogliamo essere noi a suddividerla in più query senza lasciarlo fare a Entity Framework.
Quello che è importante sapere è che Entity Framework ricostruisce le relazioni tra oggetti anche quando decidiamo di spezzare la query. Riprendendo l'esempio precedente, potremmo fare una query che tira fuori ordini e cliente e un'altra che tira fuori gli altri dati.
var q1 = await ctx.Orders .Include(c => c.Customer) .ToListAsync(); await ctx.OrderDetails .Include(c => c.Product) .ThenInclude(c => c.Supplier) .ToListAsync();
Anche se non abbiamo estratto nella stessa query l'ordine con i suoi dettagli, sfruttando le informazioni sul modello, il change tracking di Entity Framework è in grado di ricostruire di popolare anche le istanze esistenti. Nel codice dell'esempio, dopo la prima query, la proprietà Details degli ordini in q1 è vuota, ma dopo la seconda query, questa è piena anche se non abbiamo fatto una Include esplicita.
Grazie a questo meccanismo, possiamo spezzare le nostre query più complesse e sapere che alla fine gli oggetti saranno correttamente collegati anche senza scrivere codice esplicito.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare lo spread operator con i collection initializer in C#
Hosting di componenti WebAssembly in un'applicazione Blazor static
Utilizzare i primary constructor in C#
Gestione degli stili CSS con le regole @layer
Sfruttare al massimo i topic space di Event Grid MQTT
Utilizzare politiche di resiliency con Azure Container App
Criptare la comunicazione con mTLS in Azure Container Apps
Recuperare l'ultima versione di una release di GitHub
Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
Eseguire attività pianificate con Azure Container Jobs
Miglioramenti agli screen reader e al contrasto in Angular
C# 12: Cosa c'è di nuovo e interessante
I più letti di oggi
- Build 2017: segui con noi tutte le novità mercoledì 10 e giovedì 11 maggio da Seattle!
- Build 2016: segui con noi in live streaming!
- Microsoft Visual Studio Code: un nuovo editor gratuito per Windows, MacOSX e Linux per sviluppatori ASP.NET e Node.js
- ASP.NET 4.5 e Visual Studio 2012 Live - Online
- Utilizzare QuickGrid di Blazor con Entity Framework
- Gestire la cancellazione di una richiesta in streaming da Blazor
- Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
- Microsoft Security Bulletin MS02-026
- Speciale per il lancio di Visual Studio 2008, SQL Server 2008 e Windows Server 2008 dal 25/02 al 07/03
- Eseguire query in parallelo con Entity Framework Core and ASP.NET Core