Il metodo SaveChanges della classe DbContext è virtuale e quindi possiamo eseguirne l'override nella classe di contesto che creiamo nei nostri progetti. Grazie a questa caratteristica possiamo eseguire operazioni prima e dopo l'effettiva persistenza dei dati sul database.
Un tipico esempio in cui questa funzionalità torna utile è quando vogiamo ripulire le stringhe inserite dall'utente da caratteri speciali prima che questi vengano persistiti. Il seguente esempio mostra come sfruttare il metodo SaveChanges per raggiungere tale scopo.
public override int SaveChanges()
{
var entries = this.ChangeTracker.Entries().Where(
c => c.State == EntityState.Added || c.State == EntityState.Modified);
foreach (var entry in entries)
{
foreach (var propertyName in entry.CurrentValues.PropertyNames)
{
var property = entry.Property(propertyName);
if (property.IsModified && property.CurrentValue is string)
{
string r = "[\x00-\x08\x0B\x0C\x0E-\x1F]";
property.CurrentValue = Regex.Replace(
property.CurrentValue.ToString(), r, "", RegexOptions.Compiled);
}
}
}
return base.SaveChanges();
}Prima che si esegua la persistenza, vengono recuperate tutte le entry nel DbContext che devono essere modificate o aggiunte sul database. Per ogni entry si scorrono le proprietà. Su quelle che sono di tipo stringa e modificate viene eseguita una regular expression per eliminare i valori non consentiti. Alla fine si invoca il l'implementazione di base di SaveChanges per eseguire la persistenza.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
Response streaming con Blazor e .NET 10
Utilizzare Intersect e Except per filtrare set di dati in TSql
Utilizzare ExecuteUpdate per aggiornare colonne JSON in Entity Framework
Supportare la crittografia di ASP.NET Core con Azure Container App
Semplificare i deployment con le label in Azure Container App
Evitare memory leaks nelle closure JavaScript
Mappare una complex property di una entity su un campo JSON
Ottimizzare la content-visibility in CSS specificando lo spazio da occupato dall'area non renderizzata
Proteggere l'endpoint dell'agente A2A delle Logic App
Evidenziare una porzione di testo in un pagina dopo una navigazione




