Quando con la versione 6 di EF Core utilizziamo il metodo SaveChanges o la sua controparte asincrona, EF Core genera automaticamente una transazione ed esegue i comandi all?interno di essa. Prendiamo come esempio il seguente codice.
using var ctx = new MyContext(); ctx.Customers.Add(customer); ctx.Orders.Add(order); ctx.Logs.Add(log); ctx.SaveChanges();
Se loggassimo i comandi inviati al database, noteremmo che il primo comando è "Begin Transaction", seguito dai comandi per inserire i tre record seguiti a loro volta dal comando "Commit Transaction" o "Rollback Transaction" rispettivamente se i comandi precedenti sono stati eseguiti correttamente o meno. 
Quando dobbiamo eseguire comandi multipli (ad esempio aggiornare più tabelle o inserire più record), l'utilizzo di una transazione è necessario, ma quando dobbiamo eseguire un solo comando, la situazione cambia. Quando dobbiamo persistere un solo oggetto e quindi generare un solo comando, il database gestisce autonomamente la transazione e EF può quindi evitare di crearne una esplicitamente risparmiando due round-trip con il database (uno per iniziare la transazione e uno per completarla). Per questo motivo, a partire da EF 7 quando si deve persistere un solo oggetto, i comandi per gestire la transazione non verranno più generati ottimizzando le performance. Il risultato è che il seguente codice genra un solo comando SQL.
using var ctx = new MyContext(); ctx.Customers.Add(customer); ctx.SaveChanges();
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
- .NET Aspire per applicazioni distribuite
- Recuperare App Service cancellati su Azure
- Utilizzare Containers in .NET Aspire
- Utilizzare l'espressione if inline in una pipeline di Azure DevOps
- Esporre tool MCP con Azure Functions
- Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
- Recuperare gli audit log in Azure DevOps
- Recuperare automaticamente un utente e aggiungerlo ad un gruppo di Azure DevOps
- Gestione degli eventi nei Web component HTML
- Anonimizzare i dati sensibili nei log di Azure Front Door
- Ottimizzare le pull con Artifact Cache di Azure Container Registry
- Autenticazione di git tramite Microsoft Entra ID in Azure DevOps


