Eseguire query senza tracking degli oggetti in Entity Framework Core

di Stefano Mostarda, in LINQ, Entity Framework,

Quando eseguiamo una query, Entity Framework tiene traccia degli oggeti recuperati così da poter persistere eventuali modifiche e da poter mantenere una sola istanza in memoria per ogni oggetto letto. Queste funzionalità hanno un costo in termini di performance, quindi, quando abbiamo query in sola lettura, possiamo disabilitarle.
Per disabilitare il tracking a livello di query è sufficiente invocare il metodo AsNoTracking esattamente come mostrato nel prosimo esempio.

using (var ctx = new MyContext())
{
  var people1 = ctx.People.AsNoTracking().Where(p => p.Name.StartsWith("S")).ToList();
  var people2 = ctx.People.Where(p => p.Name.StartsWith("T")).ToList();
}

In questo caso, gli oggetti estratti dalla prima query non vengono tracciati mentre quelli della seconda query vengono tracciati. Questa funzionalità era già presente in Entity Framework 6, ma in Entity Framework Core è stata anche aggiunta la possibilità di disabilitare il tracking a livello di context impostanto la variabile ChangeTracker.QueryTrackingBehavior.

using (var ctx = new MyContext())
{
  ctx.ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
  var people1 = ctx.People.Where(p => p.Name.StartsWith("S")).ToList();
  var people2 = ctx.People.Where(p => p.Name.StartsWith("T")).ToList();
}

In questo caso anche senza il metodo AsNoTracking, gli oggetti della prima e della seconda query non vengono tracciati.

Commenti

Visualizza/aggiungi commenti

| Condividi su: Twitter, Facebook, LinkedIn

Per inserire un commento, devi avere un account.

Fai il login e torna a questa pagina, oppure registrati alla nostra community.

Approfondimenti

I più letti di oggi