IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

[SQL] Problème de requête SQL


Sujet :

PHP & Base de données

  1. #1
    Invité
    Invité(e)
    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 : Sélectionner tout - Visualiser dans une fenêtre à part
    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

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    882
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 882
    Points : 691
    Points
    691
    Par défaut
    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 : Sélectionner tout - Visualiser dans une fenêtre à part
    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 "

  3. #3
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 644
    Points
    4 644
    Par défaut
    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

  4. #4
    Invité
    Invité(e)
    Par défaut
    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.

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bon voilà !

    je crois que c'est bon.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    if (empty ($prix_max))
    	{
     	$requete = mysql_query("SELECT * FROM critere WHERE 
    <div style="margin-left:40px">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());</div>        }
    	else
    	{$requete = mysql_query("SELECT * FROM critere WHERE 
    <div style="margin-left:40px">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());</div>	}
    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 !!!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [SQL] Problème de requête sql utilisant LIKE
    Par yakup.67 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 06/06/2007, 13h31
  2. [SQL] problème avec requête sql
    Par belakhdarbts10 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 14/05/2007, 11h58
  3. [SQL] problème de requête sql d'insertion
    Par belakhdarbts10 dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 10/05/2007, 14h11
  4. [SQL] Problème de requête SQL
    Par nico26 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 25/01/2007, 16h40
  5. [SQL] Problème de requête SQL de plus de 8060 caractères ?
    Par webtheque dans le forum MS SQL Server
    Réponses: 13
    Dernier message: 06/04/2005, 15h07

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo