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

Requêtes MySQL Discussion :

rechercher une chaine avec deux termes sur champs différents


Sujet :

Requêtes MySQL

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    472
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 472
    Points : 121
    Points
    121
    Par défaut rechercher une chaine avec deux termes sur champs différents
    Bonjour à tous,

    Je ne trouve pas de solution, voici mon problème :

    J'ai une table avec la structure suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    meta_id 	bigint(20)
    post_id 	bigint(20)
    meta_key 	varchar(255)
    meta_value	longtext
    Dans cette table j'ai des données de cette manière :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    	632311	38396	prenom	DIDIER
    	632312	38396	nom	        COSTEAUX
    J'ai une recherche sur mon site avec un champ d'entrée permettant d'aller rechercher dans cette table. Celui-ci est intitulé "nom ou prenom".

    Quand le visiteur saisi un nom ==> pas de soucis.
    Quand le visiteur saisi un prenom ==> pas de soucis.
    Par contre quand le visiteur saisi un nom et un prenom aucun résultat ne sort malgrès le fait que la donnée existe. Et pour cause ma requete est constituée comme cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    ...
    AND ((meta_key = "nom" AND meta_value LIKE "%didier costeaux%") OR (meta_key = "prenom" AND meta_value LIKE "%didier costeaux%")) 
    ...
    Ce qui fait qu'aucun résultat ne peux apparaître de cette manière.
    selon moi il y a deux approches, soit en découpant la chaîne saisie en entrée par le visiteur mais savoir quelle valeur correspond à quelle clef (nom ou prénom).

    Sinon la seconde approche est de concatener les nom & prenom au moment de la recherche.

    La seconde approche me parait la plus logique, mais impossible de combiner les concact et le fait de devoir toujours coupler avec la meta_key.

    Est ce que quelqu'un aurait une idée ? Merci de votre aide !!!

  2. #2
    Membre éclairé Avatar de ypcman
    Homme Profil pro
    Retraité codeur !
    Inscrit en
    Janvier 2011
    Messages
    597
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité codeur !
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2011
    Messages : 597
    Points : 886
    Points
    886
    Par défaut
    Ça devrait fonctionner avec
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    meta_value IN ('didier','costeaux')
    Mais ça ne fournira pas de bons résultats dès que tu chercheras des personnes dont le nom de famille est un prénom ..
    Participez vous aussi !
    Message utile
    Discussion résolue

  3. #3
    Membre averti
    Profil pro
    Administrateur
    Inscrit en
    Mai 2008
    Messages
    237
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Administrateur
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2008
    Messages : 237
    Points : 433
    Points
    433
    Par défaut
    Pour quoi ne pas mettre deux champs nom et prénom dans la table. Il me semble que le modélisation de la table pose problème.

Discussions similaires

  1. Rechercher une chaine sur une partie du champ
    Par docjo dans le forum VBA Access
    Réponses: 6
    Dernier message: 12/08/2009, 17h04
  2. Une requête avec un Max sur 2 champs
    Par Bils dans le forum Langage SQL
    Réponses: 4
    Dernier message: 17/09/2007, 14h04
  3. Concaténation d'une chaine avec un champ
    Par arjo54 dans le forum Access
    Réponses: 0
    Dernier message: 27/07/2007, 13h34
  4. recherche d'une chaine avec Like
    Par pierre2410 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 25/05/2007, 11h37
  5. [SQL2K]Requete sur une chaine avec une ou plusieurs quote
    Par tazamorte dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 17/04/2007, 08h22

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