Quando si lavora con SQL Azure esiste la possibilità che un errore di rete faccia fallire le query e le scritture sul database. Possiamo limitare questo problema utilizzando la configurazione da codice di Entity Framework e impostando le strategie che in automatico riprovano se una connessione fallisce per problemi di rete così come mostrato nel seguente codice.
public class PeopleConfiguration : DbConfiguration { public PeopleConfiguration() { SetExecutionStrategy(SqlProviderServices.ProviderInvariantName, () => new SqlAzureExecutionStrategy()); SetTransactionHandler(SqlProviderServices.ProviderInvariantName, () => new CommitFailureHandler()); } }
Il metodo SetExecutionStrategy imposta la strategia di retry per SQL Azure grazie alla classe SqlAzureExecutionStrategy. Il metodo SetTransactionHandler imposta la strategia di gestione della connessione. Se si usa la classe CommitFailureHandler questa crea una tabella nel database e crea una riga per ogni transazione. Se la transazione fallisce, sarà cura di Entity Framework cercare di portarla a buon fine in maniera trasparente.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sfruttare al massimo i topic space di Event Grid MQTT
Ordine e importanza per @layer in CSS
Evitare il flickering dei componenti nel prerender di Blazor 8
Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
Creare un webhook in Azure DevOps
Ordinare randomicamente una lista in C#
Generare un hash con SHA-3 in .NET
Gestione dei nomi con le regole @layer in CSS
Change tracking e composition in Entity Framework
Usare le navigation property in QuickGrid di Blazor
Creazione di componenti personalizzati in React.js con Tailwind CSS
Utilizzare Container Queries nominali