Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD > PHP & MySQL
PHP & MySQL Forum d'entraide sur les fonctions MySQL avec PHP. Avant de poster -> FAQ MySQL, Cours MySQL et Sources MySQL. Pour les questions concernant le moteur MySQL plutôt que les fonctions PHP, merci d'utiliser le forum MySQL.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 05/02/2012, 17h49   #1
Membre actif
 
Inscription : juin 2006
Messages : 545
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 545
Points : 174
Points : 174
Par défaut Influence de l'ordre des conditions dans la clause WHERE

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.
morgan47 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/02/2012, 17h57   #2
Modérateur
 
Inscription : septembre 2010
Messages : 7 240
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 240
Points : 8 625
Points : 8 625
fait un EXPLAIN pour voir
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/02/2012, 18h33   #3
Membre actif
 
Inscription : juin 2006
Messages : 545
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 545
Points : 174
Points : 174
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
morgan47 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/02/2012, 18h40   #4
Modérateur
 
Inscription : septembre 2010
Messages : 7 240
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 240
Points : 8 625
Points : 8 625
idmembre, ip, idads et dateclic sont des INDEX ?
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 05/02/2012, 18h46   #5
Membre actif
 
Inscription : juin 2006
Messages : 545
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 545
Points : 174
Points : 174
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.
morgan47 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/02/2012, 22h46   #6
Membre actif
 
Inscription : juin 2006
Messages : 545
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 545
Points : 174
Points : 174
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.
morgan47 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 18h04.


 
 
 
 
Partenaires

Hébergement Web