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 :

Recherche lié à plusieurs tables [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 53
    Par défaut Recherche lié à plusieurs tables
    Bonjour,

    je n'arrive pas a faire ma recherche... je vais essayé d'etre clair pour qu'une ame charitable m'aide.

    1) J'ai une table nommée : ville qui comprend le champ CODEPOSTAL,VILLE avec tous les code postaux et ville de france.

    2) J'ai une table annonces qui contient uniquement le champ CP.

    3) Mon formulaire est un champ input text.

    Je souhaiterai faire que par exemple :
    je saisi dans le champ : bordeaux ca fasse une recherche dans ma table ville : WHERE cp='Bordeaux' OR cp LIKE 'bordeaux%' OR ville LIKE 'bordeaux'.

    Immaginons, nous avons 5 résultats, je souhaite récuperer uniquement les code postaux des villes trouvées pour effectuer maintenant ma deuxieme requete et rechercher dans les annonces WHERE cp='xxxxx' OR cp='xxxxxx' etc......

    J'anticipe une question "Pourquoi mettre cp LIKE 'bordeaux%' " Tout simplement car a la place de bordeaux, on peut saisir un cp, ville ou departement.

    Quelqu'un peut m'aider ?

    J'ai fait une requete qui me retourne bien tout les codepostaux avec

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $complement_requete='';
    while($rse = mysql_fetch_array($resultats)) {
    $complement_requete.=" OR ((cp = '".$rse['ZIP']."') OR (cp LIKE '".$rse['ZIP']."%')) ";
    }
    Le problème est que le complement de ma requete commence par OR mais je souhaiterai que le 1er résultat affiche AND et les autres résultats affiche OR.

    Merci pour vos lumières.

  2. #2
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 323
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 323
    Par défaut
    Bonjour

    mais pourquoi pas une seule requete type:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $search=trim(strip_tags($_POST['search']));
    if is_numeric($search)
        select * from annonces where cp  like $search% ;
    else
        select * from annonces where cp IN
            (select cp from villes where (departement like $search%) OR (ville like $search%));

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 53
    Par défaut
    Merci pour ta réponse.

    En faite pourquoi pas une requete direct, car ma requete est un truc du genre :

    select * from annonce WHERE statut='0' ".$complement_requete."

    et dans mon moteur de recherche j'ai d'autres champ et tout le complement de la requete est dynamique suivant les champs rempli..

    L'idée serait d'inclure les code postaux qui se trouve dans la table ville que l'on trouve en fonction de la recherche et les inclure dans $complement_requete.

    Exemple si je tape bordeaux, ca retournera : 33000,33800,33200... et c'est la ou ma requete doit commencer par "AND" et pour les autres cp commence par OR.

    je sais pas si je suis clair... desolé par avance... lol

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

Discussions similaires

  1. [MySQL] recherche dans plusieurs tables
    Par minimoof dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 07/08/2007, 07h58
  2. Recherche sur plusieurs tables
    Par micatmidog dans le forum Langage SQL
    Réponses: 2
    Dernier message: 09/06/2007, 16h28
  3. [MySQL] moteur de recherche sur plusieurs tables
    Par harlock59 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 10/04/2007, 15h23
  4. recherche dans plusieurs tables
    Par rostomides dans le forum Bases de données
    Réponses: 7
    Dernier message: 16/03/2007, 08h34
  5. [MySQL] Recherche sur plusieurs tables
    Par hubidev dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 21/03/2006, 10h42

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