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 :

Requête préparée et AGAINST


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Janvier 2024
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Enseignant Chercheur

    Informations forums :
    Inscription : Janvier 2024
    Messages : 105
    Par défaut Requête préparée et AGAINST
    Bonjour

    Le problème que j'ai est le suivant

    Comment utiliser une requête préparée avec MATCH ?

    Le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $stmt = mysqli_prepare($bdd, "SELECT adresse FROM groupes_index WHERE groupe LIKE ?");
    Fait ce que je veux mais avec un seul mot provenant d'un formulaire de recherche et qui remplace le "?" grace à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysqli_stmt_execute($stmt, [$_GET["Mot"]]);
    D'après mon expérience "AGAINST ?" ne fonctionne pas.
    Que doit-on écrire pour que

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $stmt = mysqli_prepare($bdd, "SELECT adresse FROM groupes_index WHERE MATCH(groupe)  AGAINST ?");
    fonctionne ?

    Pour info, la table "groupe_index" est bien indexée et "groupe" est FULLTEXT

    Merci

  2. #2
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 344
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 344
    Billets dans le blog
    17
    Par défaut
    Avant de compliquer la situation avec PHP et les préparations de requête, il faut tester la requête dans un client MySQL.

    Tu te rendras compte que ta syntaxe n'est pas bonne.

    La bonne syntaxe est :

    SELECT adresse
    FROM groupes_index
    WHERE MATCH (groupe) AGAINST ('Ma recherche');
    Donc pour préparer la requête :

    SELECT adresse
    FROM groupes_index
    WHERE MATCH (groupe) AGAINST (?);
    L'intérêt de MATCH/AGAINST étant les recherches approximatives, généralement on procède ainsi :

    SELECT adresse, MATCH (groupe) AGAINST (?) AS score
    FROM groupes_index
    HAVING score > 0
    ORDER BY score DESC;
    https://dev.mysql.com/doc/refman/8.4...tatements.html
    https://dev.mysql.com/doc/refman/8.4...t-boolean.html
    Un problème exposé clairement est déjà à moitié résolu
    Keep It Smart and Simple

Discussions similaires

  1. Requte Sql Avancée, question ... ? Estce possible ?
    Par plex dans le forum Administration
    Réponses: 8
    Dernier message: 14/12/2005, 15h13
  2. requte avec points de suspension
    Par Luther13 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 08/12/2005, 16h56
  3. [Requete] Intersection de requte
    Par KorHeve dans le forum Langage SQL
    Réponses: 5
    Dernier message: 11/04/2005, 17h45
  4. Requte
    Par abdallahi dans le forum Access
    Réponses: 6
    Dernier message: 04/01/2005, 15h06
  5. petit probleme dans une requte POSTGRE SQL
    Par ghis le fou dans le forum Requêtes
    Réponses: 5
    Dernier message: 08/09/2003, 13h51

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