Nella service release 8.0.2, EF introduce un nuovo metodo: EF.Constant. Questo metodo scrive il valore di un parametro direttamente nel codice SQL generato da Entity Framework invece che usare la parametrizzazione nativa SQL.
Prendiamo come esempio le seguenti query.
public async Task Method(int age) { var people1 = await ctx.People .Where(p => p.Age > age) .ToListAsync(); var people2 = await ctx.People .Where(p => p.Age > EF.Constant(age)) .ToListAsync(); }
Nel primo caso, il valore della variabile age viene passato come parametro SQL, mentre nel secondo caso il valore di age viene direttamente scritto nel codice.
//query 1 select * from people where age = @age //query 2 select * from people where age = 20
In linea generale, mettere nella stringa SQL un parametro non è il massimo in quanto si genera un query plan per ogni valore di age con conseguenti effetti sulle perforance del database. Tuttavia, possono esistere casi in cui mettere inline il valore può tornare utile e quindi avere EF.Constant è un'arma in più.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Creare una libreria CSS universale: Clip-path
Usare i servizi di Azure OpenAI e ChatGPT in ASP.NET Core con Semantic Kernel
Recuperare l'ultima versione di una release di GitHub
Ottimizzare le performance usando Span<T> e il metodo Split
.NET Conference Italia 2024
Ottenere un token di accesso per una GitHub App
Supportare la sessione affinity di Azure App Service con Application Gateway
Recuperare le subissue e il loro stato di completamento in GitHub
Centralizzare gli endpoint AI Foundry con Azure API Management
Change tracking e composition in Entity Framework
Simulare Azure Cosmos DB in locale con Docker
Utilizzare Containers in .NET Aspire