Molto spesso ci troviamo nella situazione di dover recuperare i dati di una collection navigation property ma di dover filtrare questi dati. Un tipico esempio di questa situazione è quando vogliamo recuperare una lista di clienti e i loro ultimi 5 ordini. Fino alla versione 3, Entity Framework Core permette di recuperare gli ordini legati ai clienti ma non offre la possibilità di filtrarli in alcun modo. Questo significa che se un cliente ha 500 ordini questi vengono recuperati tutti causando un enorme spreco di risorse.
Entity Framework Core 5 aggiunge la possibilità di utilizzare i metodi LINQ Where, OrderBy, OrderByDescending, ThenBy, ThenDescending, Take e Skip all'interno della lambda del metodo Include così da poter filtrare i record collegati che vengono recuperati.
using (var context = new MyContext()) { var customers = context.Customers .Include(c => c.Orders .Where(o => o.OrderDate <= DateTime.Now.AddMonth(-3)) .OrderByDescending(o => o.Date) .Take(5) ) .ToList(); }
In questa query vengono recuperati tutti i clienti e i relativi ultimi 5 ordini (per data ordine) fatti negli ultimi 3 mesi ordinati. Prima di questa nuova funzionalità, potevamo comuqnue filtrare i dati, ma avremmo dovuto ricorrere a subquery e tipi anonimi complicando notevolmente il codice. Grazie a questa aggiunta, non dobbiamo più ricorrere a simili tecniche con grande risparmio di tempo di sviluppo e anche maggior efficiena a run time.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Selettore CSS :has() e i suoi casi d'uso avanzati
Eliminare record doppi in Sql Server
Supportare la crittografia di ASP.NET Core con Azure Container App
Eseguire script pre e post esecuzione di un workflow di GitHub
Triggerare una pipeline su un altro repository di Azure DevOps
Montare Azure Blob Storage su Linux con BlobFuse2
Creare una libreria CSS universale: Clip-path
Referenziare un @layer più alto in CSS
Change tracking e composition in Entity Framework
Ricevere notifiche sui test con Azure Load Testing
Recuperare gli audit log in Azure DevOps
I più letti di oggi
- Novità nella gestione del modello asincrono in C# 5 e VB 11
- Eseguire query con LINQ to SQL
- Conoscere il rendering Server o WebAssembly a runtime in Blazor
- Gestione file Javascript in Blazor con .NET 9
- Migliorare la velocità delle connessioni ai database
- #vs2017 sarà rilasciato il 07/03, in concomitanza con i suoi 20 anni https://aspit.co/bfn
- #VS2017 Community è già disponibile al download da questa pagina https://aspit.co/bgb
- #VS2017 non ha un'ISO, ma è possibile creare un installer offline seguendo la guida ufficiale: https://aspit.co/bgd
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!