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 :

Requête sur plusieurs mots pour moteur de recherche [MySQL]


Sujet :

PHP & Base de données

  1. #1
    fey
    fey est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 231
    Points : 93
    Points
    93
    Par défaut Requête sur plusieurs mots pour moteur de recherche
    bonjour,

    voila j'ai fais un petit moteur de recherche qui fonctionne tres bien et qui cherche sur plusieurs champs.

    le truc c'est que pour le moment, il gere qu'un seul mot.

    ma question est quelle est la syntaxe pour pouvoir rechercher à partir de plusieurs mots ?


    au depart je pensais a un mot clef a preciser lors de la recerche puis dans la page de traitement faire un split sur ce mot clef, mais apres je vois pas trop comment il faut faire, pour pouvoir selectionner les infos en fonction de ce que retourne le split.

    donc si vous avez des idees/suggestions .... ?

    merci
    fey

  2. #2
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    Salut,
    le principe de base c'est de coller des LIKE %% avec des OR ou des AND selon ce que tu veux:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $keywords = array('mot1', 'mot2');
    $sql = "SELECT * FROM table WHERE champ1 LIKE %".implode('% OR champ1 LIKE %',$keywords)."%";
    Sinon tu peux jeter un coup d'oeil vers la recherche full-text de MySql qu'est bien intéressante et elle gère directement des opérateurs, au final tu te retrouves avec des trucs du styles pour gérer tes ET/OU :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    +pizza +gratuit -anchois chevre

  3. #3
    fey
    fey est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 231
    Points : 93
    Points
    93
    Par défaut
    pour le like c'est ce que j'utilise, mais l'implode je connaissais pas ^^

    dans tous les cas, merci je vais tester avec ce que m'a donne

  4. #4
    fey
    fey est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 231
    Points : 93
    Points
    93
    Par défaut
    re,
    je viens d'essayer full-text avec phpmyadmin et il me met :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Impossible de trouver un index FULLTEXT correspondant à cette liste de colonnes
    il faut juste que les colonnes soient indexees, ou il y a autre chose a faire ?

  5. #5
    Membre à l'essai
    Inscrit en
    Octobre 2007
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 17
    Points : 21
    Points
    21
    Par défaut
    Bonjour,

    As-tu remarqué qu'il faut déclarer tes colonnes de recherche en FULLTEXT:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    mysql> CREATE TABLE articles (
        ->   id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
        ->   title VARCHAR(200),
        ->   body TEXT,
        ->   FULLTEXT (title,body)
        -> );

  6. #6
    fey
    fey est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 231
    Points : 93
    Points
    93
    Par défaut
    je cherchais justement ou et comment on les declarait ^^

  7. #7
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    Sinon dans PhpMyAdmin tu cliques sur le T dans les actions d'un champ. Vérifie aussi que ton futur hébergeur soit en 4.1, je crois que c'est à partir de cette version, histoire que ça ne fonctionne pas qu'en local ^^.

  8. #8
    fey
    fey est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 231
    Points : 93
    Points
    93
    Par défaut
    yep
    bon bizzard quand je met plus d'un champ il me jete alors que lorsqu'il y en a 1 seul c'est bon
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Erreur SQL !
    SELECT id_machine,emplacement,lieu FROM infos WHERE MATCH (id_machine, matricule, machmod, emplacement, lieu, ip, code_recherche) AGAINST ('75') ORDER BY id_machine
    Impossible de trouver un index FULLTEXT correspondant à cette liste de colonnes
    j'ai peut etre zape quelque chose ?

    par compte on dirait qu'avec fulltext recherche, cela recherche l'expression exacte.
    il y a une possibilite pour que cela retourne quelque chose comme le LIKE ?

    merci

  9. #9
    fey
    fey est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 231
    Points : 93
    Points
    93
    Par défaut
    pour l'histoire des colonne qui posait probleme j'ai resolu.

    mais comment je pourrais faire pour avoir a la fois la methode fulltext c'est a dire l'histoire des + et des - (entre autre) et avoir la recherche moins stricte sur la chaine du caractere, un peu comme le like ?

  10. #10
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    Tu peux ne pas mettre d'opérateurs si tu veux et les mots sont optionnels. Je crois que c'est ça que tu veux ? Il y a tous les opérateurs dans la doc.

    A moins que tu parles de la troncature ? dans ce cas il faut utiliser *
    Tu peux laisser l'utilisateur le faire ou tu peux l'ajouter toi-même à chaque mots-clé.

  11. #11
    fey
    fey est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 231
    Points : 93
    Points
    93
    Par défaut
    yep c'etait de cela que je parlais (mais je me rappelais plus du nom :p)

    ceci dis, je viens d'essayer et il me trouve aucun resultat.
    arf, si cela continu je vais rester sur le like

  12. #12
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 737
    Points
    11 737
    Par défaut
    Il faut créer un index avec les deux colonnes dedans, sinon ça ne marche pas :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    create fulltext index MonIndexFT on articles(title, body) ;

    La requête avec recherche sur des mots-clés tronqués doit se faire en mode booléen :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select *
    from articles
    where MATCH(title, body) AGAINST ('présiden* républi*' IN BOOLEAN MODE)

  13. #13
    fey
    fey est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Janvier 2003
    Messages : 231
    Points : 93
    Points
    93
    Par défaut
    en fait j'avais oublie de mettre "IN BOOLEAN MODE" :p

    merci

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 28/05/2010, 20h08
  2. recherche sur plusieur mot
    Par Invité dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 29/09/2009, 13h47
  3. Question pour une requête sur plusieurs tables/objets
    Par pontus21 dans le forum Hibernate
    Réponses: 54
    Dernier message: 01/06/2009, 18h37
  4. [MySQL] Recherche sur plusieurs mots clés
    Par loupsolitaire dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 04/10/2008, 17h48
  5. Recherche sur plusieurs mots-clés
    Par Freedolphin dans le forum Installation
    Réponses: 3
    Dernier message: 10/12/2007, 02h11

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