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 :

match against et % ou autre jocker


Sujet :

PHP & Base de données

  1. #1
    Membre régulier Avatar de carelha
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Mars 2006
    Messages : 168
    Points : 109
    Points
    109
    Par défaut match against et % ou autre jocker
    bonjour,

    j'ai un formulaire avec un champ texte pour chercher des mots clefs. J'utilise la syntaxe match against, mais je n'ai pas trouvé dans la doc comment l'employer (si c'est possible !) pour chercher une partie d'un mot.
    par exemple, dans la bdd, j'ai "patients atteints de la maladie d'Alzheimer", mais si on rechercher "Alzheimer", la recherche aboutit à 0 résultat.

    qqn a une solution (autre que mettre un espace entre ' et Alzheimer ) ?

    merci à vous

  2. #2
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Janvier 2004
    Messages
    1 249
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 249
    Points : 1 565
    Points
    1 565
    Par défaut
    est ce que LIKE %$mot% ne suffirais pas ?

  3. #3
    Membre expert Avatar de Amara
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    2 688
    Détails du profil
    Informations personnelles :
    Localisation : France, Sarthe (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 688
    Points : 3 115
    Points
    3 115
    Par défaut
    Avec juste des quotes en plus.


  4. #4
    Membre régulier Avatar de carelha
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Mars 2006
    Messages : 168
    Points : 109
    Points
    109
    Par défaut
    j'y ai pensé, j'ai essayé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    
    MATCH (activite, description) AGAINST ("%'.$_SESSION['mot'].'%" IN BOOLEAN MODE)
    
    sans succès...

  5. #5
    Membre expérimenté

    Homme Profil pro
    Inscrit en
    Janvier 2004
    Messages
    1 249
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 249
    Points : 1 565
    Points
    1 565
    Par défaut
    La doc pour match against :
    http://dev.mysql.com/doc/refman/4.1/...xt-search.html


    Par contre, je ne connais pas cet operateur, pourquoi ne pas utiliser LIKE ?

    tu peux faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE activite LIKE '%$mot%' OR description LIKE '%$mot%'
    si tu veux mapper 2 champs, ou encore :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE CONCAT(activite, description) LIKE '%$mot%'
    meme si c'est sans doute moins optimisé que match against

  6. #6
    Membre régulier Avatar de carelha
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Mars 2006
    Messages : 168
    Points : 109
    Points
    109
    Par défaut
    merci, mais je n'ai pas trouvé ma réponse dans la doc. Like c'est OK pour un seul mot, mais quand tu veux pouvoir en mettre plusieurs, ca se complique, les requêtes sont plus complexes à écrire qu'avec match against

  7. #7
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    82
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 82
    Points : 78
    Points
    78
    Par défaut
    il est vrai que cela devient plus ch*** pour les requetes voila un tit exmple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $tab=explode(" ",$_POST['recherche']);
     
    $req="where activite like '%".$tab[0]."%'";
    $req2="OR description like '%".$tab[0]."%'";
     
    for($i=1;$i<count($tab);$i++){
       $req.=" OR activite like '%".$tab[$i]."%'";
       $req2=" OR description like '%".$tab[$i]."%'";
    }
    Après tu insere ca dans ta requete a l'endroit ou il fo et c du tout bon !!

  8. #8
    Membre régulier Avatar de carelha
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Mars 2006
    Messages : 168
    Points : 109
    Points
    109
    Par défaut
    A défaut je retournerai vers ça, mais j'ai déjà des requêtes complexes, une petite ligne de code toute simple aurait été parfaite !

  9. #9
    Membre régulier Avatar de carelha
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Mars 2006
    Messages : 168
    Points : 109
    Points
    109
    Par défaut
    Pour info, on peut ajouter * à la fin du mot, mais au début il ne sert à rien.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AGAINST ("*'.$_SESSION['mot'].'*" IN BOOLEAN MODE)';
    si on cherche plante

    on trouvera dans les résultats plantes

    mais pas replante

    Si quelqu'un a encore mieux, je prends !

Discussions similaires

  1. MATCH() AGAINST(), un cas bizarre !
    Par ygrim dans le forum Installation
    Réponses: 13
    Dernier message: 13/09/2007, 18h38
  2. Match against et pertinence.
    Par ddelec24 dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 26/07/2007, 16h54
  3. Probleme avec "match against"
    Par biggione dans le forum Requêtes
    Réponses: 1
    Dernier message: 10/03/2007, 15h57
  4. Problème recherche match.. against
    Par pierre_pogo dans le forum Requêtes
    Réponses: 2
    Dernier message: 01/08/2006, 11h45
  5. [MySQL] MATCH AGAINST et $-session
    Par carelha dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 25/04/2006, 15h57

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