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
Usare un KeyedService di default in ASP.NET Core 8
.NET Conference Italia 2024
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Assegnare un valore di default a un parametro di una lambda in C#
Miglioramenti nell'accessibilità con Angular CDK
Creare gruppi di client per Event Grid MQTT
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Potenziare Azure AI Search con la ricerca vettoriale
Creare una custom property in GitHub
Aggiungere interattività lato server in Blazor 8
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Supportare il sorting di dati tabellari in Blazor con QuickGrid
I più letti di oggi
- Centrare elementi in HTML tramite CSS
- Proteggere le risorse Azure con private link e private endpoints
- Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
- Referenziare un @layer più alto in CSS
- Gestire i dati con Azure Cosmos DB Data Explorer
- Inference di dati strutturati da testo con Semantic Kernel e ASP.NET Core Web API