Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD
PHP & SGBD Forum d'entraide sur les SGBD avec PHP. Avant de poster : FAQ BDD, toutes les FAQ PHP, cours BDD et sources BDD
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 03/09/2006, 06h16   #1
Invité régulier
 
Inscription : juin 2006
Messages : 20
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 20
Points : 5
Points : 5
Par défaut [SQL] Problème de requête SQL

Bonjour,

j'ai un probleme sur lequel j'ai passé beaucoup de temps et malgré mes recherches sur le net. J'ai rien trouvé de concluant.

EXPLICATIONS :
J'essaye de faire un formulaire de recherche.
J'ai une requete qui fait des siennes.
La partie qui me pose probleme est en rouge.

Code :
1
2
3
4
5
6
7
8
9
 //Requête SQL          
 $requete = mysql_query("SELECT * FROM critere WHERE
 motorisation like '%$motorisation% ' AND
 marque like '%$marque%' AND
 modele like '%$modele%' AND
 annee like '%$annee%' AND
 type like '%$type%' AND
 (prix between '$prix_mini' and '$prix_max') ")    or die(mysql_error());
En fait elle s'execute correctement si dans le formulaire correspondant
je met un prix mini et un prix max. C'est tout.
Si je met seulement une marque ou un modele ou une combinaison marque type par exemple le script s'execute et je n'ai aucune erreur.
Mais je n'obtiens aucun resultat. C'est à dire que la requete ne renvoi rien.

J'ai essayer aussi avec des inegalités c'est à dire :
(prix > '$prix_mini' AND prix < '$prix_max')
il me fait pareille, le script s'execute mais pas de resultat. En revanche, si j'enleve
AND prix < '$prix_max' là ma requete me renvoi des resultats normaux et je peux faire une recherche à un ou plusieurs criteres.

Il est 6h30 du matin et je suis sur ce truc depuis samedi matin. 24h quoi. C'est surement un truc bête mais là je suis plus trop en forme.
J'espère que quelqu'un pourra m'aider.

Et MERCI d'avance pour le temps consacré à mon message.

YOPYOP
yopyopLeVrai est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/09/2006, 10h53   #2
Membre expérimenté
 
Inscription : octobre 2004
Messages : 872
Détails du profil
Informations forums :
Inscription : octobre 2004
Messages : 872
Points : 582
Points : 582
salut

essaye en elevant les simples quotes, car je pense que $prix_mini et $prix_max sont des int ou float, mais pas des chaines de caractère
Code :
1
2
3
4
5
6
7
8
9
 
 
"SELECT * FROM critere WHERE
 motorisation like '%$motorisation% ' AND
 marque like '%$marque%' AND
 modele like '%$modele%' AND
 annee like '%$annee%' AND
 type like '%$type%' AND
 prix between $prix_mini and $prix_max "
jeff_! est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/09/2006, 11h51   #3
Modérateur
 
Avatar de Cybher
 
Homme Michel
Consultant informatique
Inscription : mai 2005
Messages : 3 006
Détails du profil
Informations personnelles :
Nom : Homme Michel
Âge : 29
Localisation : France

Informations professionnelles :
Activité : Consultant informatique
Secteur : Conseil

Informations forums :
Inscription : mai 2005
Messages : 3 006
Points : 4 039
Points : 4 039
le probleme est que si tu ne rempli pas la valeur max, aucun de tes enregistrement ne correspondra
en effet, le prix ne sera jamais inférieur à rien.
tu peux construire ta requete en fonction de la case ei elle est renseigné ou non

bon courage

Michel
Cybher est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/09/2006, 14h39   #4
Invité régulier
 
Inscription : juin 2006
Messages : 20
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 20
Points : 5
Points : 5
Rebonjour,

merci pour les reponses.

Pour les quotes j'ai essayer ce n'est pas ca.

Pour ce qui est de prix_max, je pense aussi que c'est ca le probleme.

Je vais donc essayer de corriger cela, je reviens quand j'ai la reponse.
yopyopLeVrai est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/09/2006, 15h18   #5
Invité régulier
 
Inscription : juin 2006
Messages : 20
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 20
Points : 5
Points : 5
Bon voilà !

je crois que c'est bon.

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 
if (empty ($prix_max))
	{
 	$requete = mysql_query("SELECT * FROM critere WHERE <blockquote>motorisation like '%$motorisation%' AND
marque like '%$marque%' AND
modele like '%$modele%' AND
annee like '%$annee%' AND
type like '%$type%'AND
prix > '$prix_mini'  ") or die(mysql_error());
</blockquote>        }
	else
	{$requete = mysql_query("SELECT * FROM critere WHERE <blockquote>motorisation like '%$motorisation%' AND
marque like '%$marque%' AND
modele like '%$modele%' AND
annee like '%$annee%' AND
type like '%$type%'AND
prix > '$prix_mini' AND prix < '$prix_max'  ") or die(mysql_error());</blockquote>	}
Donc on peux mettre résolu. A moins que vous ayez autre choses à me proposer.

Je voudrais juste mettre le doigt sur un problème que l'on ne soulève jamais assez sur les forums.
Il ne faut pas s'amusez à vouloir être trop productif (sauf pour les experts), je suis rester trop longtemps à travailler. Plus je continuais plus je m'éloignais de la solution.

Et là en une demi heure, c'est fait.

Enfin grâce à vous. MERCIIIIIIIIIIIIII !!!
yopyopLeVrai 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 05h44.


 
 
 
 
Partenaires

Hébergement Web