Molto spesso capita di voler loggare le operazioni di modifica al database per motivi di storicizzazione. Quando non si può centralizzare questa logica in una stored procedure, il modo migliore è ricorrere all'override del metodo SaveChanges della classe ObjectContext. In questo modo possiamo intercettare il momento in cui Entity Framework persiste le modifiche fatte agli oggetti ed agganciare la logica di logging.
Il primo passo consiste nel creare una classe che erediti da ObjectContext. Il secondo passo consiste nel fare l'override del metodo SaveChanges come nel seguente esempio.
public override int SaveChanges(SaveOptions options) { DetectChanges(); var result = base.SaveChanges(SaveOptions.None); //codice di logging AcceptAllChanges(); return result; }
Il metodo SaveChanges della classe base viene invocato passando SaveOptions.None così che quando il codice torna nel nostro metodo, lo stato delle entità non è impostato su Unchanged e possiamo così effettuare il log.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Montare Azure Blob Storage su Linux con BlobFuse2
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Potenziare la ricerca su Cosmos DB con Full Text Search
Testare l'invio dei messaggi con Event Hubs Data Explorer
Loggare le query più lente con Entity Framework
Migliorare la scalabilità delle Azure Function con il Flex Consumption
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Esporre i propri servizi applicativi con Semantic Kernel e ASP.NET Web API
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
Centralizzare gli endpoint AI Foundry con Azure API Management
Utilizzare DeepSeek R1 con Azure AI