Nello script #420 abbiamo visto come utilizzare il metodo Include per precaricare un grafo di oggetti collegati in una singola query con Entity Framework Core. Questa tecnica è efficace ma il caricamente del grafo viene invalidato nel momento in cui terminiamo la query con un comando Select il cui risultato è diverso dalla classe da cui siamo partiti per eseguire la query. Prendiamo come esempio le seguenti query.
var orders1 = ctx.Order.Include(o => o.Customer).ToList(); var orders2 = ctx.Order.Include(o => o.Customer) .Select(o => new { o.id, o.OrderDate, o.Customer.Id });
La prima query usa Include per caricare in una sola query l'oridne e il cliente. La seconda query ignora Include in quanto il tipo restituito è un tipo anonimo. In questi casi il compilatore solleva un warning, ma possiamo anche fare in modo che venga sollevata un'eccezione usando il metodo ConfigureWarnings in fase di configurazione del DbContext.
protected override void OnConfiguring (DbContextOptionsBuilder optionsBuilder) { optionsBuilder .ConfigureWarnings(warnings => warnings.Throw(CoreEventId.IncludeIgnoredWarning)); }
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Creare alias per tipi generici e tuple in C#
Usare lo spread operator con i collection initializer in C#
Utilizzare Tailwind CSS all'interno di React: primi componenti
Eseguire una query su SQL Azure tramite un workflow di GitHub
Eseguire una GroupBy per entity in Entity Framework
Ottenere il contenuto di una cartella FTP con la libreria FluentFTP
Usare un KeyedService di default in ASP.NET Core 8
Creare gruppi di client per Event Grid MQTT
Disabilitare automaticamente un workflow di GitHub
Come migrare da una form non tipizzata a una form tipizzata in Angular
Creazione di plugin per Tailwind CSS: espandere le funzionalità del framework dinamicamente
Effettuare il binding di date in Blazor