|
Publicité ' | |||||||||||||||||||||||
|
|
#1 |
|
Membre actif
![]() Inscription : juin 2006 Messages : 545 ![]() |
Bonjour,
A cause de pas mal de slow query j'essai d'optimiser une requète, et je me demande si l'ordre des conditions dans la clause where à une influence. Ma reuquète est exécuté sur une table de 200000 lignes environ. Code mysql :
SELECT COUNT(idmembre) AS nbr FROM clics WHERE (idmembre = '$idmembre' OR ip = '$ip') AND idads = '$idads' AND dateclic = '$today' LIMIT 1 Requête toute simple mais qui prend du temps, on vérifie que le membre (ou l'ip) à cliquait sur cette bannière aujourd'hui. Et je me demande si le fait d'inverser l'ordre va accélérer la requête, car la condition dateclic = '$today' est beaucoup plus restrictive que (idmembre = '$idmembre' OR ip = '$ip') Merci pour vos réponses. |
|
|
00
|
|
|
#2 |
![]() ![]() Inscription : septembre 2010 Messages : 7 240 ![]() |
fait un EXPLAIN pour voir
__________________
http://blog.stealth35.com/ |
|
|
00
|
|
|
#3 |
|
Membre actif
![]() Inscription : juin 2006 Messages : 545 ![]() |
Voila le résultat :
id select_type table type possible_keys key key_len ref rows Extra 1 SIMPLE clics index idmembre idmembre 27 NULL 192687 Using where; Using index |
|
|
00
|
|
|
#4 |
![]() ![]() Inscription : septembre 2010 Messages : 7 240 ![]() |
idmembre, ip, idads et dateclic sont des INDEX ?
__________________
http://blog.stealth35.com/ |
|
|
00
|
|
|
#5 |
|
Membre actif
![]() Inscription : juin 2006 Messages : 545 ![]() |
Oui :
Nom de l'index idmembre Colonne | Cardinalité | idmembre 404 idads 96358 ip 192716 dateclic 192716 J'ai testé de mettre en moteur de stockage memory, plus de requête lente, mais si je reboot ou survient un crash je pers tout. |
|
|
00
|
|
|
#6 |
|
Membre actif
![]() Inscription : juin 2006 Messages : 545 ![]() |
J'ai créé un 4 index sur les 4 colonnes, au lieu de créer un index incluant les 4 colonnes.
je vais bien vois si il y a une différence. |
|
|
00
|
Copyright © 2000-2012 - www.developpez.com