Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
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
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


Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
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+ ...
007 First Light ha venduto più di...
Harley-Davidson, svelato il prezzo itali...
PC Windows 11 in crash: ma la colpa è di...
Dopo i 'NO 5G' arrivano i 'NO FIBRA'? Ar...
Promettono un parco e costruiscono un da...
L'aeroplano supersonico ''silenzioso'' N...
Euro-Office sbugiardata da LibreOffice: ...
I 10 sconti TOP Amazon: 4 novità ...
Galaxy Z Flip 8, in Europa avrà i...
SpaceX annuncia i satelliti AI1 destinat...
Ariston DEOS 10 EVO a 103€: deumidificat...
Cina pronta a investire 295 miliardi di ...
Gli israeliani di NSO Group continuano a...
AMD scommette 2 miliardi di sterline sul...
WhatsApp annuncia la fine del supporto p...
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: 16:56.


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