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 :

[PHP/MySQL] Recherche multicritères "souple" avec score


Sujet :

Requêtes MySQL

  1. #1
    Membre du Club
    Inscrit en
    Mars 2005
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 60
    Points : 55
    Points
    55
    Par défaut [PHP/MySQL] Recherche multicritères "souple" avec score
    Bonjour,

    Je cherche depuis quelque temps à faire une requête MySQL pour faire une recherche à partir de n critères mais de manière "souple", l'idée étant que la requête ne remonte pas uniquement les enregistrements matchant exactement aux n critères donnés, mais aussi ceux qui matcheraient avec 1 à n-1 critères. Un champ virtuel "score" doit cependant être construit afin de sanctionner la pertinence des enregistrements remontés, à savoir : 100% si l'on matche avec tous les n critères, 100*(n-1/n)% si l'on matche avec n-1 critères, ... et ainsi de suite (on remonte bien entendu rien si l'on ne matche avec aucun critère).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT matable.id, score FROM matable WHERE -- score est "virtuel"
      test1 -- si test1 est vrai, score recoit 20% de plus dans cet exemple
      test2 -- si test1 est vrai, score recoit 20% de plus dans cet exemple
      test3 -- si test1 est vrai, score recoit 20% de plus dans cet exemple
      test4 -- si test1 est vrai, score recoit 20% de plus dans cet exemple
      test5 -- si test1 est vrai, score recoit 20% de plus dans cet exemple
    ORDER BY score DESC
    J'aurais pu arriver à ce résultat de manière "crade" en faisant toutes les combinaisons possibles de requêtes selon les critères, et faire ma sauce (en PHP dans mon cas), mais niveau performance je pense que ça n'est pas optimal, d'autant plus que je suis persuadé que MySQL est autosuffisant pour faire ça.
    Merci d'avance à ceux qui peuvent m'aider avec leurs idées/bouts de codes/liens...

    Joe

  2. #2
    Membre averti Avatar de Nheo_
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    323
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 323
    Points : 416
    Points
    416
    Par défaut
    Bonjour,

    Je n'ai pas de solution à te proposer, mais tu pourrais utiliser tout simplement des variables avec MySQL : Doc.

    Il suffirait d'incrémenter ta variable selon tes tests.

    Je précise que je n'ai jamais testé ceci, donc je ne peux rien te garantir .

  3. #3
    Membre du Club
    Inscrit en
    Mars 2005
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 60
    Points : 55
    Points
    55
    Par défaut
    Bonjour Nheo,

    Merci pour ta réponse.
    Je suis déjà passé par cette doc, mais le souci, comme ils le disent, c'est qu'on peut pas déclarer ET incrémenter une variable dans une même commande (la variable reste toujours à sa valeur d'initialisation).
    Donc point mort quoi

    Joe

  4. #4
    Membre du Club
    Inscrit en
    Mars 2005
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 60
    Points : 55
    Points
    55
    Par défaut
    Je viens de trouver!
    Je laisse ici le code au cas ça servirait à quelqu'un :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
    SELECT *, (
      IF(test1, 1, 0) +
      IF(test2, 1, 0) +
      IF(test3, 1, 0) + 
      IF(test4, 1, 0) + 
      IF(test5, 1, 0)
    ) / 5 * 100 AS score
    FROM matable
    WHERE
      test1 OR
      test2 OR
      test3 OR
      test4 OR
      test5
    ORDER BY score DESC

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

Discussions similaires

  1. Réponses: 23
    Dernier message: 14/03/2007, 19h02
  2. [php/mySQL]Recherche par motclé sur toute la base
    Par boniface dans le forum Requêtes
    Réponses: 1
    Dernier message: 30/06/2006, 14h54

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