Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-02-2009, 14:22   #1
GHz
Senior Member
 
L'Avatar di GHz
 
Iscritto dal: Sep 2001
Città: Vicopisano (PI)
Messaggi: 11652
[MySql/PHP] Ottimizzazione algoritmo aggiornamento tabella

Ciao a tutti,
avrei bisogno di un consiglio di qualcuno esperto di mysqp/php per ottimizzare un algoritmo di aggiornamento di un a tabella. Spiego come funziona.

C'è una tabella dei progetti e una degli utenti.

Per ogni utente, ci sono diversi record nella tabella utenti in base ai progetti seguiti dall'utente. Quindi se un utente segue 2 progetti, nella tabella utenti ci saranno 2 record di quell'utente.
Ad ogni utente, per ciascun progetto è associato un punteggio. Quindi la tabella utenti è fatta in questo modo:

Codice_Utente (VARCHAR 32), Punteggio (DOUBLE), Codice_Progetto ( INT 3)

Il Codice_Progetto è un intero, invece il Codice_Utente è una stringa (un hash md5), che identifica univocamente l'utente sui vari progetti.

Per fare le statistiche sui punteggi, devo sapere la posizione di ciascun utente in un singolo progetto oppure considerando tutti i progetti, facendo la somma dei punteggi sui vari progetti raggruppando per Codice_Utente. Per questo ho aggiunto 2 campi alla tabella, uno chiamato Pos_Progetto e un'altro Pos_Totale, che aggiorno con uno script.
Per l'aggiornamento del campo Pos_Progetto non c'è problema, è molto veloce (meno di un secondo), invece per l'aggiornamento di Pos_Totale ci mette diversi minuti.
Lo script legge la tabella in ordine di punteggio raggruppando per hash e per ogniuno va a scrivere il campo Pos_Totale. Io penso che sia lento perchè la ricerca sul campo di tipo stringa è molto lenta, mentre la ricerca per quello numerico (nel caso di Pos_Progetto avviene su un intero che non ho riportato in questo esempio per semplificare) è velocissima.
La tabella degli utenti contiene attualmente circa 9000 record, e raggruppando per utente vengono circa 5000 record. Andando a vedere il tempo di esecuzione dello script in dettaglio, per aggiornare la posizione totale di un singolo utente ci mette circa 0,1 secondi, per farne 100 ci impiega infatti circa 10 secondi. Per aggiornarli tutti ci mette una vita.
Vi riporto lo script incriminato:
Codice:
//aggiorna il rank degli utenti in classifica combinata
function updatecombinedranks()
{
	$sql = "SELECT SUM(Punteggio) as TC, Codice_Utente FROM tabellautenti GROUP BY Codice_Utente ORDER BY TC DESC";
	$combined = query_fetch($sql);
	$count = count($combined);
	echo "COUNT = ". $count."<br/>";
	for ($i = 0; $i<$count ; $i++)
	{
		$sql = "UPDATE tabellautenti SET Pos_Totale = ".($i+1)." WHERE Codice_Utente = \"".$combined[$i]['Codice_Utente']."\"";
		if (!mysql_query($sql))
		{
			echo "Errore su Codice_Utente = ".$combined[$i]['Codice_Utente'];
		}
    }
}
C'è un modo per ottimizzare questa procedura? Qualcuno ha già affrontato un problema simile?

Grazie, ciao,
GHz
__________________
>>PARTECIPA AI PROGETTI DI CALCOLO DISTRIBUITO CON BOINC.Italy!<<
You may say I'm a dreamer - But I'm not the only one - I hope someday you'll join us - And the team will be the 1# one
BoincEmperor 1° Livello - Rotoloni DOCET!! Cactus rulez!!
GHz è offline   Rispondi citando il messaggio o parte di esso
Old 20-02-2009, 14:27   #2
beppegrillo
Senior Member
 
L'Avatar di beppegrillo
 
Iscritto dal: Mar 2004
Messaggi: 1455
Non comprendo i motivi per il quale utilizzi come chiave un hash di una stringa, e non cresi semplicemente una nuova tabella ID,NOME_UTENTE a cui le altre faranno riferimento come chiave esterna.
__________________
Ciao ~ZeRO sTrEsS~
beppegrillo è offline   Rispondi citando il messaggio o parte di esso
Old 20-02-2009, 14:50   #3
GHz
Senior Member
 
L'Avatar di GHz
 
Iscritto dal: Sep 2001
Città: Vicopisano (PI)
Messaggi: 11652
Quote:
Originariamente inviato da beppegrillo Guarda i messaggi
Non comprendo i motivi per il quale utilizzi come chiave un hash di una stringa, e non cresi semplicemente una nuova tabella ID,NOME_UTENTE a cui le altre faranno riferimento come chiave esterna.
Non è che mi voglio fare del male è che i dati che ho a disposizione sono in quel formato.
Ogni progetto è indipendente e ogni utente ha un suo id nel progetto (intero, che non ho riportato prima per semplificare e che uso per aggiornare il campo Pos_Progetto), e questo hash per identificare l'utente tra i vari progetti.
__________________
>>PARTECIPA AI PROGETTI DI CALCOLO DISTRIBUITO CON BOINC.Italy!<<
You may say I'm a dreamer - But I'm not the only one - I hope someday you'll join us - And the team will be the 1# one
BoincEmperor 1° Livello - Rotoloni DOCET!! Cactus rulez!!
GHz è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2009, 09:07   #4
GHz
Senior Member
 
L'Avatar di GHz
 
Iscritto dal: Sep 2001
Città: Vicopisano (PI)
Messaggi: 11652
UP, nessuno ha qualche idea/suggerimento?
__________________
>>PARTECIPA AI PROGETTI DI CALCOLO DISTRIBUITO CON BOINC.Italy!<<
You may say I'm a dreamer - But I'm not the only one - I hope someday you'll join us - And the team will be the 1# one
BoincEmperor 1° Livello - Rotoloni DOCET!! Cactus rulez!!
GHz è offline   Rispondi citando il messaggio o parte di esso
Old 23-02-2009, 11:37   #5
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Ti scrivo una possibile soluzione per Oracle e una per Sql-Server, dato che MySql non lo tocco da un po' e le funzioni analitiche non so se sono completamente supportate.

Codice:
SQL-Server : 

UPDATE tabellautenti
FROM (
	SELECT Codice_Utente, 
            ROW_NUMBER() OVER (ORDER BY TC DESC) pos FROM (
	        SELECT SUM(Punteggio) as TC, Codice_Utente 
                          FROM tabellautenti GROUP BY Codice_Utente
        )
) src
SET tabellautenti.Pos_Totale = src.pos
WHERE tabellautenti.Codice_Utente = src.Codice_Utente


Codice:
Oracle:

UPDATE 
(
SELECT tabellautenti.Codice_Utente, tabellautenti.Pos_totale,
           ROW_NUMBER() OVER (ORDER BY TC DESC) pos FROM (
	   SELECT Codice_Utente, SUM(Punteggio) as TC  FROM 
                    tabellautenti GROUP BY Codice_Utente
        ) src
       JOIN tabellautenti on tabellautenti.Codice_Utente = src.CodiceUtente)
SET Pos_totale = pos;
PS: Ho scritto al volo, quindi puo' esserci qualche errore di sintassi, ma il concetto e' che consiglio di fare tutto in un unico statement di Update, senza conivolgere il linugaggio imperativo di turno e dando un occhio all'ottimizzatore.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 23-02-2009 alle 11:40.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 24-02-2009, 12:17   #6
GHz
Senior Member
 
L'Avatar di GHz
 
Iscritto dal: Sep 2001
Città: Vicopisano (PI)
Messaggi: 11652
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Ti scrivo una possibile soluzione per Oracle e una per Sql-Server, dato che MySql non lo tocco da un po' e le funzioni analitiche non so se sono completamente supportate.

PS: Ho scritto al volo, quindi puo' esserci qualche errore di sintassi, ma il concetto e' che consiglio di fare tutto in un unico statement di Update, senza conivolgere il linugaggio imperativo di turno e dando un occhio all'ottimizzatore.
Molto interessante la tua soluzione, vedo che di database te ne intendi
Avevo visto tempo fa qualche articolo in rete che spiegava come fare gli aggiornamenti in mysql in un unico statement di update, però era un pò più complicato perchè mysql non ha la funzione per sapere la posizione del record (ROW_NUMBER) e va simulata con delle variabili.....devo studiarci un pò e fare qualche prova.
Intanto grazie, se hai qualche altro consiglio/esempio posta pure!

Ciao,
GHz
__________________
>>PARTECIPA AI PROGETTI DI CALCOLO DISTRIBUITO CON BOINC.Italy!<<
You may say I'm a dreamer - But I'm not the only one - I hope someday you'll join us - And the team will be the 1# one
BoincEmperor 1° Livello - Rotoloni DOCET!! Cactus rulez!!
GHz è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
Quale tecnologia preferisci? Faccelo sap...
Bloodborne approda al cinema: Sony Pictu...
Robot umanoide mette in fuga un branco d...
Stati Uniti, export di chip AI a rilento...
Microsoft ritocca al rialzo i prezzi dei...
Internet Archive sotto attacco: perch&ea...
Intel Nova Lake: possibile CPU desktop c...
Windows 11, il primo avvio sarà m...
Speciale Offerte Amazon: le migliori TV ...
OpenText punta sul cloud sovrano e strin...
Recensione HUAWEI MatePad 11.5 S 2026: l...
Game Pass è diventato troppo cost...
Windows 11 sblocca il FAT32: Microsoft r...
3 Modem Router FRITZ! hanno prezzi eccez...
Dreame L10s Ultra Gen 2, ottimo robot as...
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: 11:21.


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