Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-12-2007, 14:42   #1
Dix 3
Senior Member
 
L'Avatar di Dix 3
 
Iscritto dal: Jan 2002
Messaggi: 1024
[mysql] Transazione....

io dovrei fare una cosa del genere

Codice:
SELECT  m.*
FROM Messaggio m
IF(m.DeleteMit=1 AND m.DeleteDes=1) 
THEN DELETE FROM m ELSE UPDATE m SET m.deleteMit = 1 ENDIF
WHERE m.Id = ?
cioe in pseudocodice
Codice:
Messaggio m = new messaggio(IDMESSAGGIO)

if(m.deleteMit == 1 &&  m.deleteDes == 1){
CancellaMessaggio();
}else{
UpdateMessaggio();
}
esiste un modo per fare una trasazione in questo modo o devo farlo con la transazione in java..??
__________________
Dix 3 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 14:48   #2
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
ELIMINA CON LA WHERE E POI LANCI L'UPDATE CHE SE, SE E' STATO ELIMINATO IL RECORD CHE DOVREBBE AGGIORNARE SEMPLICEMENTE NON FA NIENTE ALTRIMENTI AGGIORNA
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 14:51   #3
Dix 3
Senior Member
 
L'Avatar di Dix 3
 
Iscritto dal: Jan 2002
Messaggi: 1024
Codice:
SELECT  m.*
FROM Messaggio m
IF(m.DeleteMit=1 AND m.DeleteDes=1) 
THEN DELETE FROM m WHERE m.Id = ? 
ELSE UPDATE m SET m.deleteMit = 1 WHERE m.Id = ? 
ENDIF
dici cosi?
__________________
Dix 3 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 14:55   #4
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Intendevo lanciarle separatamente

Codice:
DELETE FROM MESSAGGIO WHERE DELETEMIT=1 AND DELETEDES=1 WHERE ID=?
Poi subito dopo lanci
Codice:
UPDATE MESSAGGIO SET DELETEMIT=1 WHERE ID= ?
Cosi se l'hai eliminata, l'update non farà niente perche la condizione where non verra trovata.
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 14:58   #5
Dix 3
Senior Member
 
L'Avatar di Dix 3
 
Iscritto dal: Jan 2002
Messaggi: 1024


Sei proprio un FURBACCHIONE...

Guistissimo..

Ma questo se lo metto dentro una stessa query mi garantisce l'atomicità dell'operazione??
__________________
Dix 3 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:00   #6
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:06   #7
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Devi eseguirle separatamente una dopo l'altra
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:07   #8
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Magari se mi spieghi con precisione il meccanismo con il quale gestisci gli update e le delete ti posso dare una soluzione piu elegante
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:15   #9
Dix 3
Senior Member
 
L'Avatar di Dix 3
 
Iscritto dal: Jan 2002
Messaggi: 1024
Quote:
Originariamente inviato da isAlreadyInUse Guarda i messaggi
SCUSAMI.... ma il problema è di nuovo presente..

Perchè io sono obbligato temporalmente prima a fare
Codice:
UPDATE Messaggio SET DeleteMit=1 WHERE Id= ?;
oppure
Codice:
UPDATE Messaggio SET DeleteDes=1 WHERE Id= ?;
poi devo eliminare il messaggio nel CASO dopo aver fatto l'update deve eliminare il Messaggio.. Questo per non trovarmi messaggi con tutti e due i campi ad 1..

__________________
Dix 3 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:17   #10
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Allora un trigger che scatta dopo l'update e ti elimina nel caso ci siano le condizioni
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:18   #11
Dix 3
Senior Member
 
L'Avatar di Dix 3
 
Iscritto dal: Jan 2002
Messaggi: 1024
Io nel Db devo avere solo messaggi con i campi deleteDes AND deleteMit != entrambi da 1..

se dopo un update si verifica che entrambi i campi sono ad 1 deve eseguira la DELETE..

Il problema che deve essere atomica...
__________________
Dix 3 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:18   #12
Dix 3
Senior Member
 
L'Avatar di Dix 3
 
Iscritto dal: Jan 2002
Messaggi: 1024
Quote:
Originariamente inviato da isAlreadyInUse Guarda i messaggi
Allora un trigger che scatta dopo l'update e ti elimina nel caso ci siano le condizioni
Ok... Forse ci siamo..

GRAZIE MILLE...

__________________
Dix 3 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:19   #13
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Atomica?
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:24   #14
Dix 3
Senior Member
 
L'Avatar di Dix 3
 
Iscritto dal: Jan 2002
Messaggi: 1024
Quote:
Originariamente inviato da isAlreadyInUse Guarda i messaggi
Atomica?
Nel senso di transazione (rimasugli di c ).. anche se adesso con un trigger credo che non se ne abbia bisogno..
__________________
Dix 3 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 15:25   #15
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Secondome con un trigger fai piu bella figura
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 12-12-2007, 07:45   #16
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
In MySQL non tutti gli engine sono transazionali: InnoDB e NDS (per realizzare cluster) sicuramente (forse anche BerkeleyDB, ma al momento non ricordo).

Quindi per eseguire "atomicamente" quelle operazioni ti serve un db che sfrutti uno di quegli engine.

Per il resto, potresti racchiuderle tutte in una stored procedure, che a partire da MySQL 5 sono supportate da MySQL (e idem per i trigger che, comunque, da soli NON risolvono certo il problema dell'atomicità dell'esecuzione delle operazioni).
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
TIM, rincari da luglio: come evitare l'a...
WWDC 26: Il Digital Markets Act dell'Uni...
WWDC 26: Apple Intelligence rivoluziona ...
Siri AI arriva alla WWDC 2026: nuove cap...
Alla WWDC 2026 arriva la nuova architett...
Tra schede madri, schede video e IA le n...
Nintendo, multa da 35 milioni di euro in...
L'amministrazione Trump valuta una parte...
WWDC 26: Apple rinnova il controllo pare...
Apple al WWDC 26 presenta iOS 27: Liquid...
Xbox, alla fine, dà ragione a Pla...
Minecraft Dungeons 2: Microsoft ha annun...
Synology al Computex 2026: nuova generaz...
Quobly raccoglie 115 milioni di euro per...
BYD batte sul tempo Tesla Roadster: avvi...
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: 22:14.


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