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

Langage SQL Discussion :

[MySQL] ecriture d'une requête multi-critères


Sujet :

Langage SQL

  1. #1
    Candidat au Club
    Inscrit en
    Août 2006
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 9
    Points : 4
    Points
    4
    Par défaut [MySQL] ecriture d'une requête multi-critères
    Bonjour ,

    J'ai un formulaire de recherche qui contient une zone de texte et un bouton.
    J'ai aussi une base de données mysql
    Je veux créer une requête sql type google avec un nombre non limité de mot clés et d'opérateurs : exemple :
    france et paris ou espagne et sport...

    Je ne sais pas comment formulé la requete SQL?

    Merci pour votre aide.

  2. #2
    Membre averti Avatar de Shivaneth
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2004
    Messages
    349
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2004
    Messages : 349
    Points : 341
    Points
    341
    Par défaut
    bonjour,
    le code que je te donne est fait à partir d'un champ de recherche ("rech") et d'une case option à cocher ("all") pour rechercher tous les mots saisis ou un seul d'en eux
    une fois que ton formulaire a été rempli, envoi les données en post ou en get (comme ci-dessous) à une autre page qui contiendra un code du type:


    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
     
    if(isset($_GET['rech']))
    {
      if($_GET['rech']=='')
      {
        echo"<h1>Recherche</h1>";
        echo"Veuillez saisir un critère de recherche";
      }
      elseif(strlen($_GET['rech'])<2)
      {
        echo"<h1>Recherche</h1>";
        echo"Veuillez saisir un critère de recherche de plus de 2 caractères";
      }
      else
      {
        $recherche = $_GET['rech'];
        if ($recherche==" ") 
        {
          echo"vous n'avez pas entré de mot clé." ; 
        }
        else
        {
          echo"<h1>Recherche de  : ".$recherche."";
          $db=mysql_connect(SERVEUR,login,pwd);
          mysql_select_db(base,$db) ;
          if(isset($_GET['all']))
          {
            $operateur="and";
            echo " (tous les mots)</h1><br>";
          }
          else
          {
            $operateur="or" ;
            echo " </h1><br>";
          }
          // on passe les mots recherchés en minuscules
          $recherche = strtolower($recherche);
          // on remplace les ' + , : par des espaces
          $mots = str_replace('+', ' ', trim($recherche));
          $mots = str_replace('\'', ' ', $mots);
          $mots = str_replace(',', ' ', $mots);
          $mots = str_replace(':', ' ', $mots);
          // on place les differents mots dans un tableau
          $tab = explode(' ' , $mots);
          //on compte le nbr d'élément du tableau.
          $nb = count($tab);
            //on prépare la requête SQL.
            $sql="select * from tes_ou_ta_table where  ((champ1 like '%$tab[0]%' or champ2 like '%$tab[0]%' or champ3 like '%$tab[0]%'";
            // on boucle pour integrer tous les mots dans la requête
            for($i = 1; $i < $nb; $i++) 
            {
              $sql .= "".$operateur." ( champ1 like '%$tab[$i]%' or champ2 like '%$tab[$i]%' or champ3 like '%$tab[$i]%'";
            }
            $sql.=" ) order by identifiant";
            // on execute la requête SQL.
            $result = mysql_query($sql,$db);
    essaye de reprendre ce code, il est vieux donc je ne le connais plus, je l'ai fait il y a un petit moment déjà

Discussions similaires

  1. Réponses: 7
    Dernier message: 10/03/2009, 19h02
  2. [mySQL-C]Ecriture dans une table
    Par fx007 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 05/02/2007, 15h18
  3. [Mysql] Connection delphi à une bdd sous easyphp...
    Par pataluc dans le forum Bases de données
    Réponses: 2
    Dernier message: 14/06/2004, 09h07
  4. Ecriture d'une procedure stockée XP
    Par WOLO Laurent dans le forum Langage SQL
    Réponses: 2
    Dernier message: 17/07/2003, 13h09
  5. Réponses: 13
    Dernier message: 14/06/2003, 22h15

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