Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 31-10-2015, 19:30   #1
Genymus
Senior Member
 
L'Avatar di Genymus
 
Iscritto dal: Oct 2007
Messaggi: 364
[MySQL - PHP] Riordinamento colonna progressiva

Salve,
ho un problema con una tabella.

Devo fare uno script di inserimento foto ordinate dal cliente.
Lo script lo ho fatto, però mi sembra impossibile che debba riordinare ogni volta tutta la tabella quando sposto una foto su o giù.

In pratica la mia richiesta è:
Avendo una tabella composta così:
Nome, Ordine
a, 1
b, 2
c, 3
d, 4

Come posso fare per ottenere questo risultato:
Nome, Ordine
a, 1
c, 2
b, 3
d, 4

In poche parole, voglio che eliminando, aggiornando, od inserendo una riga nella tabella in una posizione specifica, mysql ricalcoli automaticamente il valore di Ordine in modo progressivo.

C'è un modo?
Grazie
__________________
Genymus!!!
"Che cosa vorreste far incidere sulla vostra tomba?". "Torno fra 5 minuti."
"Lucido" è quando credi soltanto a metà di ciò che ti dicono. "Brillante" è quando sai a quale metà credere.
"Pensa, ogni volta che respiro muore un uomo." "Hai provato a fare qualcosa per l'alito?"

Aforismieaforismi.it
Genymus è offline   Rispondi citando il messaggio o parte di esso
Old 02-11-2015, 23:02   #2
Genymus
Senior Member
 
L'Avatar di Genymus
 
Iscritto dal: Oct 2007
Messaggi: 364
salve,
no, il numero di ordinamento è un normale int che però deve essere sempre progressivo, ma si può ripetere a seconda della categoria a cui appartiene la foto.
esempi:
cat 1 > 1234567
cat 2 > 1234

però vorrei che spostando la foto numero 5 alla prima posizione, questa diventi 1 e tutte le altre foto si shiftino in modo progressivo.
naturalmente posso fare tutto questo con query di update, ma se ho 50 foto, dovrei fare 50 query.
ovviamente potrei anche fare una procedura mysql ma volevo sapere se c'era un modo più semplice.

grazie
__________________
Genymus!!!
"Che cosa vorreste far incidere sulla vostra tomba?". "Torno fra 5 minuti."
"Lucido" è quando credi soltanto a metà di ciò che ti dicono. "Brillante" è quando sai a quale metà credere.
"Pensa, ogni volta che respiro muore un uomo." "Hai provato a fare qualcosa per l'alito?"

Aforismieaforismi.it
Genymus è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2015, 11:36   #3
Genymus
Senior Member
 
L'Avatar di Genymus
 
Iscritto dal: Oct 2007
Messaggi: 364
Esatto, ma io vorrei eseguire solo una update invece che una decina.
potrei collegare un trigger alla modifica del campo per ricalcolare la progressione, ma volevo sapere se esisteva qualcosa di già fatto di mysql, o se esistevano alternative da un punto di vista logico sul problema.

comunque grazie
__________________
Genymus!!!
"Che cosa vorreste far incidere sulla vostra tomba?". "Torno fra 5 minuti."
"Lucido" è quando credi soltanto a metà di ciò che ti dicono. "Brillante" è quando sai a quale metà credere.
"Pensa, ogni volta che respiro muore un uomo." "Hai provato a fare qualcosa per l'alito?"

Aforismieaforismi.it
Genymus è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2015, 12:15   #4
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Prima di rispondere alla tua domanda, sappi che esiste un altro modo per mantenere un ordine tra gli elementi, ovvero quello delle linked list.
La tabella ha bisogno di due colonne, ovvero una chiave primaria e un campo "next" che punterà alla chiave primaria dell'elemento successivo, l'ultimo elemento ovviamente avrà null. Serve inoltre qualcosa per identificare il primo elemento, per esempio una riga fittizia che non verrà inserita nei risultati.
La query estrae gli elementi non ordinati, l'ordinamento avviene da codice seguendo i valori del campo next.
Questo metodo è ottimo quando devi estrarre sempre tutti gli elementi dalla tabella; risulta invece inefficiente se devi paginare, perché bisogna sempre scorrere gli elementi uno alla volta per ricostruire l'ordine.

Tornando alla tua domanda, l'operazione di aggiornamento potrebbe essere automatizzata con dei trigger, oppure gestita tramite opportune query. Non è vero che se hai 50 righe devi fare 50 query, puoi farne una sola che aggiorna tutte le righe in un colpo solo.
Conviene consentire i valori duplicati sulla colonna posizione, in questo modo si risparmiano parecchi update. Supponiamo di voler spostare l'elemento 5 in posizione 2, dovrai usare questo algoritmo:
1) recuperi la chiave primaria dell'elemento in posizione 5:
SELECT id FROM tabella WHERE posizione=5 LIMIT 1
2) crei uno spazio in posizione 2 spostando gli elementi in avanti:
UPDATE tabella SET posizione=posizione+1 WHERE posizione BETWEEN 2 AND (5-1)
3) sposti l'elemento desiderato in posizione 2:
UPDATE tabella SET posizione=2 WHERE id=:id
Come vedi si riesce a fare tutto con solo 3 query.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2015, 12:36   #5
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Ehhh, 1-2 minuti è un tempo enorme, per arrivare a tanto servono milioni di righe anche su hardware scarso.
Comunque non esiste un metodo migliore in assoluto, ma di sicuro ne esiste uno più indicato in base alle esigenze specifiche. Ad esempio un'attesa di 2 minuti potrebbe essere ragionevole se l'operazione viene fatta una sola volta all'anno, mentre è inaccettabile per operazioni frequenti. Di contro il metodo delle linked list offre un tempo di accesso costante in modifica, ma penalizza la consultazione.
E' una questione di equilibrio, ragionare sul problema ed analizzare i dati è fondamentale, senza di essi si possono fare solo ipotesi.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2015, 14:31   #6
Genymus
Senior Member
 
L'Avatar di Genymus
 
Iscritto dal: Oct 2007
Messaggi: 364
Credo che la soluzione di Daniels118 sia tra le migliori: molto efficiente e senza problematiche... proprio quello che serve a me.
la funzione dovrei utilizzarla sulla parte amministrativa, che verrà usata regolarmente ma circa una volta alla settimana.
mentre il mio interesse era quello di rendere il recupero dei dati molto veloce e senza tanti fronzoli, per questo avevo pensato a fare una tabella strutturata in quel modo.
credo di aver risolto comunque.

vi ringrazio tutti per l'aiuto, siete stati tutti molto cortesi e disponibili.
__________________
Genymus!!!
"Che cosa vorreste far incidere sulla vostra tomba?". "Torno fra 5 minuti."
"Lucido" è quando credi soltanto a metà di ciò che ti dicono. "Brillante" è quando sai a quale metà credere.
"Pensa, ogni volta che respiro muore un uomo." "Hai provato a fare qualcosa per l'alito?"

Aforismieaforismi.it
Genymus è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
AMD sceglie Samsung come fornitore princ...
Gli utenti Intel possono dire addio all'...
NVIDIA: raggiungeremo almeno 1 triliardo...
Lenovo presenta workstation e server con...
Nuova BMW i3: la Serie 3 elettrica debut...
NVIDIA torna in Cina: stretto un accordo...
Vibe coding nel mirino di Apple: ecco le...
Smart TV QLED 50'' a un super prezzo: 4K...
Horizon Worlds lascia i visori Quest: Me...
Lexar compie 30 anni e cambia le regole ...
Questo SSD fornisce memoria aggiuntiva a...
PlayStation Portal si aggiorna: arriva l...
Akamai, le API nel mirino dei cyber atta...
Spider-Man: Brand New Day, finalmente on...
La serie TV di Hitman è ufficialmente fe...
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: 07:37.


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