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
Gestire gli accessi con Token su Azure Container Registry
Eseguire query in contemporanea con EF
Ricevere notifiche sui test con Azure Load Testing
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Recuperare App Service cancellati su Azure
Creare espressioni riutilizzabili nelle query LINQ per Entity Framework
Montare Azure Blob Storage su Linux con BlobFuse2
Mischiare codice server side e client side in una query LINQ con Entity Framework
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Gestire il routing HTTP in Azure Container App
Centralizzare gli endpoint AI Foundry con Azure API Management
Creare un agente A2Acon Azure Logic Apps


