Sopprimere gli errori di concorrenza quando si elimina una entity con Entity Framework 7

di Stefano Mostarda, in LINQ, Entity Framework,

Quando eseguiamo la cancellazione di una entity, Entity Framework verifica sempre che l'operazione di DELETE sul database abbia effettivamente eliminato il record e, in caso negativo, Entity Framework lancia una DbUpdateConcurrencyException. Tuttavia quando eseguiamo la cancellazione di una entity e questa risulta già cancellata, potremmo non voler sollevare alcuna eccezione visto che il risultato di cancellare il dato è stato ottenuto.

A partire da Entity Framework 7, possiamo creare un interceptor che intercetta il momento in cui Entity Framework solleva la DbUpdateConcurrencyException e sopprimere questo comportamento. L'interceptor deve implementare l'interfaccia ISaveChangesInterceptor e implementare il metodo ThrowingConcurrencyException, o la sua controparte asincrona, che viene scatenato quando Entity Framework verifica un errore di concorrenza. All'interno del metodo verifichiamo se l'errore proviene da un'operazione di delete e in caso positivo sopprimiamo l'eccezione.

public class SuppressDeleteConcurrencyInterceptor : ISaveChangesInterceptor
{
  public InterceptionResult ThrowingConcurrencyException(
    ConcurrencyExceptionEventData eventData,
    InterceptionResult result)
  {
    if (eventData.Entries.All(e => e.State == EntityState.Deleted))
    {
      return InterceptionResult.Suppress();
    }

    return result;
  }

  public ValueTask<InterceptionResult> ThrowingConcurrencyExceptionAsync(
    ConcurrencyExceptionEventData eventData,
    InterceptionResult result,
    CancellationToken cancellationToken = default) => 
      new(ThrowingConcurrencyException(eventData, result));
}

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