Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-09-2009, 12:18   #1
CercoAiutoo
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.
CercoAiutoo è offline   Rispondi citando il messaggio o parte di esso
Old 30-09-2009, 19:17   #2
anonimizzato
 
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".
  Rispondi citando il messaggio o parte di esso
Old 30-09-2009, 21:15   #3
CercoAiutoo
Member
 
Iscritto dal: Jul 2009
Messaggi: 125
Quote:
Originariamente inviato da Sgurbat Guarda i messaggi
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".
In effetti si sono a sola lettura ( tranne qualche rarissima modifica )... ma non trovo niente riguardo le compressioni delle tabelle



E per gli indici ?
CercoAiutoo è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2009, 05:25   #4
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
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.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2009, 07:07   #5
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
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
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2009, 07:10   #6
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Non serve indicizzare anche Auto, perché non viene utilizzato nella ricerca.
Si', ma se lo indicizzi, e il motore e' furbo come i DB commerciali, nella ricerca usera' solo l'indice e non tornera' indietro a leggere la tabella.
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.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2009, 07:22   #7
maulattu
Senior Member
 
L'Avatar di maulattu
 
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
maulattu è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2009, 08:20   #8
CercoAiutoo
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.
CercoAiutoo è offline   Rispondi citando il messaggio o parte di esso
Old 01-10-2009, 10:33   #9
zakmckraken
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...)
zakmckraken è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Cos'è RSL, il nuovo standard che ...
Nissan Micra EV: da 29.500 a oltre 36.00...
Processo Microsoft-ValueLicensing: cosa ...
L'edizione limitata più ambita da...
Lo sviluppatore di MSI Afterburner svela...
Quando l'AI diventa maestro: così...
Sony WH-1000XM6 già scontate su A...
NVIDIA chiede più velocità...
Windows 11 in soli 2,8 GB: con questo sc...
Panico in casa HYTE: ritirato dal mercat...
OPPO Reno14, debutto tra rooftoop esclus...
3DAIQ, il progetto di Concept Reply e TE...
Il parlamento francese contro TikTok: '&...
Apple Watch SE 2ª gen. Cellular a soli 2...
MotoE sospesa dopo il 2025: fine tempora...
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: 05:36.


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