Nello script #620 abbiamo visto come sfruttare il metodo ExecuteUpdate per creare un comando SQL di update massiva. In questo script ci occupiamo di un metodo molto simile, ma che invece che aggiornare i record li elimina: ExecuteDelete. Questo metodo possiamo metterlo alla fine di una query LINQ per lanciare la cancellazione dei record espressi nella query.
context.Products .Where(p => p.Category = "shoes") .ExecuteDelete();
In questo caso, la query LINQ filtra i record con categoria "shoes" e infine genera un comand SQL di DELETE per quei record. Il comando è il seguente.
DELETE FROM Products Where Category = "shoes"
Così come per il metodo ExecuteUpdate, ExecuteDelete non va a toccare le entity presenti già caricate nel contesto che quindi rimangono nello stato in cui si trovano anche se potrebbero essere state cancellate dal database. Per questo motivo, potrebbe tornare utile scaricare le entity dal contesto (tramite ilmetodo Clear del ChangeTracker e ricaricarle così da averle sincronizzate con il database se necessario.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON
Cambiare la chiave di partizionamento di Azure Cosmos DB
Paginare i risultati con QuickGrid in Blazor
Generare la software bill of material (SBOM) in GitHub
Usare lo spread operator con i collection initializer in C#
Utilizzare il nuovo modello GPT-4o con Azure OpenAI
Migrare una service connection a workload identity federation in Azure DevOps
C# 12: Cosa c'è di nuovo e interessante
Generare velocemente pagine CRUD in Blazor con QuickGrid
Installare le Web App site extension tramite una pipeline di Azure DevOps
Definire stili a livello di libreria in Angular