Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
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 vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
Google Pixel 9a a 361€, mai così ...
Super sconti sugli spazzolini Oral-B, an...
Aspira a 6000Pa, lava bene, costa 139€: ...
Nuove scorte: torna il portatile tuttofa...
Toyota usa giochi e premi per spingere i...
HarmonyOS ha raggiunto la soglia di sopr...
Le offerte Amazon più convenienti...
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: 17:08.


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