|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Member
Iscritto dal: Jul 2009
Messaggi: 125
|
[Mysql] Tabella con 6 Milioni di Righe ( aiuto INDICI )
Ho una tabella con 6 milioni di righe fatta cosi:
Codice:
CREATE TABLE IF NOT EXISTS `Piloti` ( `Id` int(9) NOT NULL auto_increment, `NomePilota` varchar(200) collate utf8_unicode_ci NOT NULL default '', `Auto` varchar(200) collate utf8_unicode_ci NOT NULL default '', PRIMARY KEY (`Id`), ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=1 ; Non sono molto esperto di Indici quindi volevo sapere che tipo di indici devo usare per avere il massimo delle performance con queste due query: 1) SELECT NomePilota, Auto FROM Piloti WHERE NomePilota LIKE "X%" ( Dove X è una parola di 1 o più caratteri ) 2) SELECT NomePilota, Auto FROM Piloti WHERE NomePilota="Y" ( Dove Y è un generico NomePilota) Qualsiasi aiuto o suggerimento è ben accetto ![]() Ultima modifica di CercoAiutoo : 30-09-2009 alle 14:39. |
![]() |
![]() |
![]() |
#2 |
Messaggi: n/a
|
Un consiglio che posso darti è che se le tabelle in questione sono di sola lettura puoi provare a "comprimerle" per renderle più snelle e credo anche "veloci".
|
![]() |
![]() |
#3 | |
Member
Iscritto dal: Jul 2009
Messaggi: 125
|
Quote:
![]() E per gli indici ? ![]() |
|
![]() |
![]() |
![]() |
#4 |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Questo dovrebbe andare, se MySql lavora bene come gli altri DB Commerciali
Codice:
CREATE INDEX IX_Piloti_NomePilotaAuto ON Piloti (NomePilota, Auto);
__________________
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. |
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Non serve indicizzare anche Auto, perché non viene utilizzato nella ricerca.
__________________
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 |
![]() |
![]() |
![]() |
#6 | |
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Quote:
Questo per il massimo delle prestazioni...
__________________
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. |
|
![]() |
![]() |
![]() |
#7 |
Senior Member
Iscritto dal: Mar 2005
Città: ~
Messaggi: 740
|
mmmhhh magari un btree su NomePilota?
![]()
__________________
Ciao ciao cagnolino Billy ![]() ![]() ![]() MacMini late 2009, 2.53GHz, 4GB ram, 320GB hard disk, Snow Leopard 10.8.2 - iPod Nano 6th gen. XBOX Live GamerTag: InsaneMau |
![]() |
![]() |
![]() |
#8 |
Member
Iscritto dal: Jul 2009
Messaggi: 125
|
Ho appena creato l' indice ma a occhio non vedo differenze di prestazioni
![]() E poi anche PHPMYADMIN mi dice che ci impiegano lo stesso tempo le query ( ovvero 0.0007 sec e 0.0003 sec per le due query sopracitate ) Non so se esistono altri programmi per verificare le prestazioni e il tempo che impiega ogni query. Poi avevo letto anche degli indici FULLINDEX ma non so se sono buoni nel mio caso ![]() Ultima modifica di CercoAiutoo : 01-10-2009 alle 08:27. |
![]() |
![]() |
![]() |
#9 |
Member
Iscritto dal: Apr 2004
Messaggi: 56
|
Ciao!
Se tu potessi togliere i varchar(200) e mettere dei char(200), dovrebbe rendere la tabella piu'facile da gestire per il database! (prova su una copia della tabella, e...sara'lunga..) poi con una 'repair' riordina tutto. Dopodiche'aggiunto l'indice sulla colonna interessata, si puo'provare a forzare l'indice... con ' FORCE INDEX(nome_indice_da_usare) ' ..Se poi sei con una macchina a tua completa disposizione potresti mettere gli indici su un disco rigido collegato su un canale diverso ..Se sei anche sotto Linux/Unix etc, potresti lavorare di fino sui buffers in modo da adattare quelli di mySql a quelli del sistema operativo e del disco fisico Su una base dati da 130Gb+70Gb di indici tutto questo mi ha aumentato le prestazioni di un buon 40% (avevo comunque anche join decisamente complesse e l'uso della force index, beh era piu'che un obbligo...) |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 05:36.