Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Destiny Rising: quando un gioco mobile supera il gioco originale
Destiny Rising: quando un gioco mobile supera il gioco originale
Tra il declino di Destiny 2 e la crisi di Bungie, il nuovo titolo mobile sviluppato da NetEase sorprende per profondità e varietà. Rising offre ciò che il live service di Bungie non riesce più a garantire, riportando i giocatori in un universo coerente. Un confronto che mette in luce i limiti tecnici e strategici dello studio di Bellevue
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro è un registratore digitale elegante e tascabile con app integrata che semplifica trascrizioni e riepiloghi, offre funzioni avanzate come template e note intelligenti, ma resta vincolato a un piano a pagamento per chi ne fa un uso intensivo
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 06-11-2009, 12:34   #1
mcaisco
Member
 
Iscritto dal: Jun 2006
Messaggi: 117
[SQL] Update concorrenti e livelli di isolamento

Non so se sia giusta come sezione, ma non ho trovato di meglio...

Comunque supponete di avere una semplice form di un'applicazione, che permette di gestire le informazioni di un cliente. Quindi la form gestisce un cliente alla volta (magari con pulsanti per spostarsi da un cliente all'altro). Due diversi utenti dell'applicazione vogliono modificare due campi diversi dello stesso cliente.
Utente1 aggiorna l'eta' del cliente da 30 anni a 31.
Utente2 aggiorna il numero telefonico del cliente da 555 a 666.
Quindi al momento del salvataggio, avremo due transazione di update:
T1: aggiorna eta a 31
T2: aggiorna telefona a 666

Qui quello che si vuole ottenere e' che alla fine il cliente abbia eta=31 e telefono=666, e quindi evitare situazioni intermedie (eta=31 telefono=555, o eta=30 telefono=666). Ma come si puo' evitare?
All'apertura della form, entrambi gli utenti leggono i dati del cliente ottenendo gli stessi valori (eta=30 e telefono=555). Poi contemporanemente modificano i campi della form: utente1 modifica l'eta a 31, mentre utente2 modifica il telefono a 666. Quando premono il pulsante "salva" partono le due transazione T1 e T2, ma il risulatato e' appunto uno dei due casi intermedi.
Se la sequenza e' T1-T2 l'ultimo update e' di T2 (eta=30 telefono=666)
Se la sequenza e' T2-T1 l'ultimo update e' di T1 (eta=31 telefono=555)

Tecnicamente mi pare che il livello di isolamento READ COMMITTED dovrebbe garantire che non vengano letti dati non confermati, ma in questo caso non e' di aiuto. Infatti, quale che sia la sequenza, l'utlima transazione dovrebbe attendere la commit della prima. Quindi effettivamente leggerebbe il record con i dati aggiornati dalla prima transazione, ma alla fine dei giochi, sovrascriverebbe tutto con le proprie modifiche, che creerebbero uno stato intermedio erroneo del record.

Il problema mi pare che sia sostanzialmente gia' a livello di apertura della form, cioe' e' in quel momento che vengono letti dati che potrebbero non essere piu' gli stessi al momento del salvataggio delle modifiche. In pratica bisognerebbe far in modo che gli utenti all'apertura della form leggano dati che con certezza rimarrano invariati fino al salvataggio di eventuali modifiche. E' una sorta di blocco in lettura/scrittura del record del cliente. Come e' possibile farlo?
mcaisco è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Molte novità per MongoDB: version...
Cina, stop alle GPU NVIDIA: Pechino inti...
Google Pixel 10 con sconti super: ecco q...
Apple Mac mini con chip M4 a soli 598€ s...
DJI firma la rivoluzione: ecco il Mini 5...
Si spara in Friuli Venezia Giulia, ma so...
Trasformare una sigaretta elettronica us...
Addio ai clic inutili: arriva l'app Goog...
L'autobus elettrico interurbano di Merce...
Il PPE contro il Green Deal: 'Salviamo l...
AMD lancia in segreto quattro nuovi Ryze...
Maxi blitz contro lo streaming pirata: u...
PS5: oggi l'update che introduce il Powe...
Tesla apre le vendite del Cybertruck neg...
realme Watch 5: il nuovo smartwatch arri...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 15:02.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v