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
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Utilizzare la session affinity con Azure Container Apps
Creare un'applicazione React e configurare Tailwind CSS
Utilizzare domini personalizzati gestiti automaticamente con Azure Container Apps
Creare form tipizzati con Angular
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Eseguire attività pianificate con Azure Container Jobs
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Implementare il throttling in ASP.NET Core
Routing statico e PreRendering in una Blazor Web App
Definire stili a livello di libreria in Angular
Creazione di plugin per Tailwind CSS: espandere le funzionalità del framework dinamicamente
Eseguire operazioni sui blob con Azure Storage Actions