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

 MySQL Discussion :

problème index FULLTEXT()


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2008
    Messages
    19
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2008
    Messages : 19
    Par défaut problème index FULLTEXT()
    Bonjour,

    J'ai crée une table (je travaille dans phpMyAdmin) comme suit:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
    CREATE TABLE test (
     id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
    typeProbleme VARCHAR(200),
    dateDebut date,
    etat varchar(10),
    prisEnCharge(50),
    details TEXT,
    FULLTEXT (details)
     );
    Ensuite, je lance la requête suivante:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     SELECT * FROM test
     WHERE MATCH (details) AGAINST ('probleme');
    Je précise que j'ai 2 enregistrements dans la table 'test' qui contiennent le mot "probleme" dans le champ 'details'.

    Si je ne me trompe, la requête ci-dessus devrait me retourner ces 2 enregistrements, et pourtant, elle ne retourne rien, même pas une erreur.

    Quelqu'un pourrait-il m'aider ?

    Merci d'avance !

  2. #2
    Membre éclairé Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Par défaut
    Bonsoir,

    Et comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT * FROM test
     WHERE MATCH (typeProbleme ,details) AGAINST ('probleme');
    Piste:
    D'après la doc. il manquerait un élément au script de création de la table dans FULLTEXT (details) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    CREATE TABLE test (
     id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
    typeProbleme VARCHAR(200),
    dateDebut date,
    etat varchar(10),
    prisEnCharge(50),
    details TEXT,
    FULLTEXT (typeProbleme,details)
     );
    http://dev.mysql.com/doc/refman/5.0/...xt-search.html

  3. #3
    Expert éminent
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 818
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 818
    Billets dans le blog
    14
    Par défaut
    J'ajoute que la colonne 'etat' en VARCHAR(10) devrait être externalisée dans une autre table et il ne devrait y avoir ici que la clé étrangère référençant l'identifiant de l'état.

    Peut-être idem pour la colonne 'prisEnCharge' qui de plus est mal définie puisqu'il n'y a que sa longueur et pas son type. Ça m'étonnerait que ce script de création de table fonctionne. Ou alors MySQL est décidément très permissif !
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole, en retraite... mais toujours Autoentrepreneur à l'occasion.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  4. #4
    Membre averti
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2008
    Messages
    19
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2008
    Messages : 19
    Par défaut
    D'abord, merci de vos réponses !

    Citation Envoyé par arthuro45 Voir le message
    Bonsoir,

    Et comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT * FROM test
     WHERE MATCH (typeProbleme ,details) AGAINST ('probleme');
    Piste:
    D'après la doc. il manquerait un élément au script de création de la table dans FULLTEXT (details) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    CREATE TABLE test (
     id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
    typeProbleme VARCHAR(200),
    dateDebut date,
    etat varchar(10),
    prisEnCharge(50),
    details TEXT,
    FULLTEXT (typeProbleme,details)
     );
    http://dev.mysql.com/doc/refman/5.0/...xt-search.html


    J'ai réessayé en suivant tes conseils, et lors de l'exécution de la requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     SELECT * FROM test
     WHERE MATCH (typeProbleme ,details) AGAINST ('probleme');
    j'ai un message d'erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    #1054 - Champ 'typeProbleme' inconnu dans where clause
    que je ne comprend pas vraiment...

    PS: pour la définition de 'prisEnCharge', c'est juste une fausse manip' de ma part, j'ai oubli de mettre 'varchar' avant le '(50)'.

  5. #5
    Membre éclairé Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Par défaut
    Si cela peut t'aider, voici un lien sur les Restrictions avec la recherche en texte intégral :
    http://dev.mysql.com/doc/refman/5.0/...trictions.html

Discussions similaires

  1. Problème de recherche dans un index fulltext
    Par Jejeleponey dans le forum Requêtes
    Réponses: 2
    Dernier message: 09/04/2012, 11h22
  2. [MySQL] recherche avec ou sans index FULLTEXT ?
    Par laloupiote dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 09/04/2007, 18h21
  3. indexation fulltext des mots avec un trait d'union
    Par andraz dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 12/03/2007, 17h46
  4. [index fulltext] Can't create table
    Par clemsouz dans le forum Administration
    Réponses: 11
    Dernier message: 16/05/2006, 18h37
  5. Probleme d'index fulltext assez bizarre
    Par Clovis37 dans le forum Débuter
    Réponses: 4
    Dernier message: 08/07/2005, 20h59

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