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 :

Moteur de recherche sur une table


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Homme Profil pro
    Apprentis developpeur
    Inscrit en
    Septembre 2015
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Apprentis developpeur

    Informations forums :
    Inscription : Septembre 2015
    Messages : 33
    Points : 22
    Points
    22
    Par défaut Moteur de recherche sur une table
    Salut Je veux créer un moteur de cherche sur une table nommée ''clients'' et qui comporte les champs ''prenom'' et ''nom'' mais à chaque fois que j'effectue une recherche aucun résultat ne 's'affiche , même pas un message d'erreur , j'ai beau regardé mon code mais je n'arrive pas à trouver la ou ca déconne , est ce que quelqu'un pourrait me fournir son aide<br>merci <br>voici mon code:<br>
    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
    <!DOCTYPE html> 
         <html>
     
             <head>
                   <title> Moteur de recherche</title>
                   <meta charset ='UTF-8'/>
     
             </head>
     
                <body>
                <?php
                if(isset($_POST['query']) && !empty($_POST['query']))
     
                 {
                        $query= preg_replace("#[^a-z?0-9]#i","",$_POST['query']);
     
                        $sql= "SELECT id,prenom AS title FROM clients WHERE prenom LIKE ? OR nom LIKE ?";
     
                    //conncxion a la base de données
     
                    include("fspeciales/connecter.php");
     
                    $req = $connex->prepare($sql);
                    $req->execute(array('%'.$query.'%','%'.$query.'%'));
     
                    $count = $req->rowcount();
                    if($count >= 1)
     
                          {
                             echo "$count le(s) résultat(s) trouvé(s)pour <strong>$query</strong> </hr>";
     
                                while ($data = $req->fetch(PDO::FETCH_OBJ))
     
                                {
                                  echo "#".$data->id.'- Titre: '.$data->prenom;
                                }
                          }
                    else
                          {
                            echo"0 resultat trouvé pour votre recherche :<strong>$query</strong></hr>";
                          }
                 }
     
                ?>
                   <form action=  "<?php echo $_SERVER['PHP_SELF']; ?> " methode= "post ">
                   <br>
                   <br>
                       <label for=  "query " >Entrez votre recherche :</label>
                       <input type= "search" name= "query" maxlength= "80" size= "80" id= "query"/>
                       <input type= "submit" value= "Rechercher">
                   </form>   
     
                </body>
         </html>

  2. #2
    Membre confirmé
    Avatar de kalimukti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2011
    Messages
    262
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2011
    Messages : 262
    Points : 451
    Points
    451
    Par défaut
    Hello,
    Comme ça à priori, je ne vois rien de particulier qui cloche...
    si tu fait un var_dump ou print_r de $query et de $data, est-ce que tu as les bons résultats ?
    My daughter, my laptop, my bike and my double-sticks...

  3. #3
    Membre expérimenté
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2003
    Messages
    1 303
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 303
    Points : 1 380
    Points
    1 380
    Par défaut
    Bonjour,
    sur le serveur il y a probablement un fichier log avec les erreurs.
    Christophe

    Pensez à mettre quand c'est le cas.

  4. #4
    Membre à l'essai
    Homme Profil pro
    Apprentis developpeur
    Inscrit en
    Septembre 2015
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Apprentis developpeur

    Informations forums :
    Inscription : Septembre 2015
    Messages : 33
    Points : 22
    Points
    22
    Par défaut
    Malimulki j'ai essayé var_dump sur les variables $query et $data mais toujour rien quand je tape une recherche dans le formulaire rien ne s'affiche.
    A moins que la manière dont je les integré dans le code fiat defaut j'ai fait;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
      <?php
          while ($data = $req->fetch(PDO::FETCH_OBJ))
          var_dump ($data);   
       ?>
    et

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
       <?php
          while ($data = $req->fetch(PDO::FETCH_OBJ))
          var_dump ($data);
         ?>

  5. #5
    Membre à l'essai
    Homme Profil pro
    Apprentis developpeur
    Inscrit en
    Septembre 2015
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Apprentis developpeur

    Informations forums :
    Inscription : Septembre 2015
    Messages : 33
    Points : 22
    Points
    22
    Par défaut
    excusez moi je me suis trompé pour le deuxieme code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    <?php
        $query= preg_replace("#[^a-z?0-9]#i","",$_POST['query']);
        var_dump ($query);  
       ?>

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Quand tu dis "rien ne s'affiche" tu veux dire que tu obtiens une page blanche ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    1/ commence par supprimer ta regex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                        $query = preg_replace("#[^a-z?0-9]#i","",$_POST['query']);
    Si je cherche "Jérome", ta regex transforme en "Jrome" : aucune chance de trouver !
    Ou au moins lis cette discussion : REGEX "simple" champ prénom
    A minima :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                        $query = preg_replace("#^([^a-zA-ZàáâäæçéèêëîïôœùûüÿÀÂÄÆÇÉÈÊËÎÏÔŒÙÛÜŸ \-\']+)$#Ui","", trim($_POST['query']) );
    N.B. Tu as déjà vu des noms ou prénoms avec des chiffres ?

    2/ La requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                        $sql= "SELECT id,prenom AS title ....
    Tu ne récupère ni le nom, ni le prenom, puisque tu mets un alias "title" : $data->prenom n'existe donc pas.

    3/ Respecter la casse des noms de fonctions : rowcount(); au lieu de rowCount();

    4/ la condition isset() est incluse dans !empty() (attention : l'inverse n'est pas vrai !) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(isset($_POST['query']) && !empty($_POST['query']))
    devient :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if( !empty($_POST['query']) )
    5/ Evite des mettre des espaces n'importe où :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                    <form action=  "<?php echo $_SERVER['PHP_SELF']; ?> " methode= "post ">
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
                    <form action="<?php echo $_SERVER['PHP_SELF']; ?>" methode="post">
    Dernière modification par Invité ; 07/11/2015 à 11h38.

Discussions similaires

  1. Recherche sur une table ne fonctionne pas
    Par runcafre91 dans le forum Langage
    Réponses: 2
    Dernier message: 07/03/2010, 10h32
  2. [MySQL] Moteur de recherche sur plusieurs tables
    Par lelectronique.com dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 05/01/2010, 14h12
  3. recherche sur une table
    Par lrool2014 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 29/04/2008, 12h46
  4. Recherche sur une table
    Par deutschy dans le forum Langage SQL
    Réponses: 5
    Dernier message: 08/06/2007, 10h32
  5. [MySQL] moteur de recherche sur plusieurs tables
    Par harlock59 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 10/04/2007, 15h23

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