Quando persistiamo i dati, spesso capita di dover eseguire operazioni con Entity Framework e altre operazioni con comandi che lanciano query SQL o stored procedure. Per mettere nella stessa transazione tutte le operazioni possiamo usare la classe TransactionScope oppure possiamo passare al costruttore della classe DbContext una connessione con una transazione.
Prima di invocare il metodo SaveChanges dobbiamo usare il metodo UseTransaction passando in input la transazione. In questo modo la classe DbContext userà la nostra transazione per le operazioni. Un esempio del codice è visibile nel prossimo esmepio.
using (var conn = new SqlConnection("connectionstring"))
{
conn.Open();
using (var trans = conn.BeginTransaction())
{
try
{
var sqlCommand = new SqlCommand();
sqlCommand.Connection = conn;
sqlCommand.Transaction = sqlTxn;
sqlCommand.CommandText = "delete from product where productid = 1"
//esegue una query custom
sqlCommand.ExecuteNonQuery();
using (var context = new MyContext(conn, contextOwnsConnection: false))
{
//indica al contsto di usare la nostra transazione
context.Database.UseTransaction(trans);
//attacca entità al contesto per la persistenza
...
//esegue la persistenza sfruttando la nostra transazione
context.SaveChanges();
}
//esegue il commit della transazione
trans.Commit();
}
catch
{
//esegue il rollback della transazione in caso di errori
trans.Rollback();
}
}
}Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Semplificare la gestione dei modelli con Azure AI Foundry Model Router
Abilitare il rolling update su Azure Functions flex consumption
Pubblicare un MCP Server in GitHub MCP Registry
Evidenziare una porzione di testo in un pagina dopo una navigazione
Importare un servizio esterno in .NET Aspire
Filtrare i dati in ASP.NET Core usando OpenTelemetry su Azure Monitor
Raggruppare risorse in .NET Aspire
Interagire con Azure DevOps tramite MCP Server
Utilizzo delle stepped value functions nel CSS
Eseguire i pre-commit hook di git con dependabot
Keynote .NET Conference Italia 2025
Utilizzare Locust con Azure Load Testing




