Lo storage basato su tabelle offerto da Windows Azure è un servizio che ci permette di memorizzare e interrogare in tabelle e colonne attraverso OData, e quindi con chiamate REST supportate da qualsiasi piattaforma.
Dato l'approccio disconnesso, quando recuperiamo un'entità, effettuiamo una modifica e la salviamo, siamo sottoposti a problemi di concorrenza. Altre richieste potrebbero modificare l'entità prima di noi ed è importante considerare anche questa possibilità. Per questo scopo i servizi REST delle table utilizzano l'header ETag che rappresenta un timestamp dell'entità: quanto la leggiamo ci viene restituito l'ETag, quando aggiorniamo o cancelliamo un'entità, passiamo l'ETag di riferimento. Questo permette all'engine server di comparare il timestamp e rifiutare l'operazione qualora il timestamp non coincidesse.
Ci sono situazioni però, in cui vogliamo forzare l'aggiornamento, senza porci il problema di eventuali concorrenze. Per fare questo possiamo passare come ETag il valore asterisco (*). Se utilizziamo le API .NET, per aggiornare o cancellare un'entità, dobbiamo fare l'attach dell'entità specificando, con un overload apposito, l'ETag. Nello snippet seguente è mostrato come fare:
// Ricostruisco l'oggetto var m = new MyEntity(); m.ID = 2; m.Name = "Test"; // Inserisco nel contesto l'entità ctx.AttachTo("Entities", m, "*"); // Marco l'entità come aggiornata ctx.UpdateObject(m); // Salvo i cambiamenti ctx.SaveChanges();
Nel caso in cui l'entità sia già presente nel contesto corrente, è sufficiente fare prima il Detach e procedere con il nuovo AttachTo, come nell'esempio precedente.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
Ottimizzare le pull con Artifact Cache di Azure Container Registry
Utilizzare DeepSeek R1 con Azure AI
Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
Potenziare la ricerca su Cosmos DB con Full Text Search
Eseguire script pre e post esecuzione di un workflow di GitHub
Cancellare una run di un workflow di GitHub
Referenziare un @layer più alto in CSS
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Utilizzare EF.Constant per evitare la parametrizzazione di query SQL
Utilizzare il trigger SQL con le Azure Function
Anonimizzare i dati sensibili nei log di Azure Front Door
I più letti di oggi
- Validazione automatica dei parametri in Web API con ASP.NET Core 2.1
- Recuperare i file utilizzati di recente in un'Universal App
- Applicare un'animazione al contenuto di un ContentControl nella Universal Windows Platform
- AI&ML Conference 2019 - Milano
- .NET Serverless Day - Online
- Rilasciata la versione Beta 2 di Silverlight 2.0