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
Cercare del testo con Azure Cosmos DB SQL
Effettuare l'upload di un file da Blazor su Azure Blob Storage
Effettuare il redirect da HTTP a HTTPS con la Azure CDN
Migrare da Entity Framework 6 ad Entity Framework Core 5
Versioning automatico degli Azure Storage Blob
Un pattern per gestire il pre-rendering in componenti Blazor complessi
Monitorare i messaggi di IoT hub con Azure IoT Explorer
Le novità di Entity Framework Core 5
Ottimizzare costi e prestazioni con l'autoscale di Azure Cosmos DB
Usare domini personalizzati per Azure Storage tramite CDN
Infrastructure as Code con Terraform
I più letti di oggi
- Blazor Conference 2021 - Online
- Track 1: @dbochicchio e @cristiancivera con 'Blazor for absolute beginners'Track 2: @apomic80 con 'Dynamic UI with Blazor WebAssembly'Track 3: #aspilive Seguici live su => https://aspit.co/BlazorConf-21
- Track 1: @GiampaoloTUCCI con 'Progressive Web Apps with Blazor'Track 2: @dottor con 'Blazor Tips&Tricks'Track 3: #aspilive Seguici live su => https://aspit.co/BlazorConf-21
- Track 1: @cristiancivera con 'Using Components in Blazor'Track 2: @crad77 con 'Blazor and ASP.NET Core with GraphQL and HotChocolate'Track 3: #aspilive Seguici live su => https://aspit.co/BlazorConf-21