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

EDI, CMS, Outils, Scripts et API PHP Discussion :

module de recherche sur mon site


Sujet :

EDI, CMS, Outils, Scripts et API PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Juin 2016
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2016
    Messages : 60
    Par défaut module de recherche sur mon site
    Bonjour a tous, je souhaite faire un module de recherche de mail a partir d'un numéro de dossier qu'on a entrée ( le numéro de dossier n'est pas unique dans la BDD )

    J'ai ma page de formulaire de recherche

    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
     <?php
        // définition des includes
        include("Include/coBdd.php") ;
        include ('Include/menu.php');
     
        //definition des managers
        $managerMail = new MailManager($pdo) ;
     
     
     
    ?>
     
    <!DOCTYPE html>
    <html >
      <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
     
     
        <form method="post" action="listeMail.php">
          <p>
              <label>Rechercher par num Dossier</label> :
              <input type="text" name="numDossRech" />
          </p>
     
          <p>
            <input type="submit" value="Envoyer" name = "rechercherMail">
          </p>
        </form>
     
     
     
    <br><br>

    Une fois cette recherche effectuer je devrai avoir une liste avec tous les mails qui possèdent la valeur du dossier saisie

    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
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    <!DOCTYPE html>
    <html >
      <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
          <?php
            // définition des includes
            include("Include/coBdd.php") ;
            include ('Include/menu.php');
     
     
     
     
            //definition des managers
            $managerMail = new MailManager($pdo) ;
     
        if (isset($_POST["rechercherMail"]))
        {
          $numDos = $_POST['numDossRech'] ;
          $a = $managerMail->rechercherMail($numDos) ;
          var_dump($numDos) ;
          var_dump($a) ;
        }
     
            ?>
        </head>
        <body>
            <h1> Liste des mails </h1>
     
     
             <table class="table  table-striped">
                <thead>
                    <tr>
                <th>Date</th>
                        <th>Numéro Dossier</th>
                        <th>Catégorie</th>
                        <th>Sujet</th>
                <th></th>
                    </tr>
                </thead>
     
                <tbody>
     
          <?php
            $lesMail = $managerMail->getList();
     
            foreach ($lesMail as $unMail)
                {
     
                  ?>
                  <tr>
                   <th>  <?php echo $unMail->getDate() ; ?> </th>
                    <th> <?php echo $unMail->getNumDossier() ; ?> </th>
                    <th> <?php echo $unMail->getCat();   ?> </th>
                    <th> <?php echo $unMail->getSujet() ; ?> </th> 
                    <th> <?php echo '<a href=consulterMail.php?id='.$unMail->getId().'> '?> Consulter
                    </a>
                    </th> 
                  </tr>
                  <?php
                }
     
         ?>
     
     
     
        </body>

    Mon var_dump($a) me retourne un objet vide je sais pas pourquoi alors que le var_dump d'avant me donne ce que j'ai saisie avant

    Ma fonction recherche ( je ne sais pas si c'est comme ça qu'il faut faire )

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    public function rechercherMail($numDossier){
        $q = $this->db->prepare("SELECT * FROM mail WHERE mai_numDossier= ".$numDossier);
        $q->execute();
        $mails = [];
     
         while ($donnees = $q->fetch(PDO::FETCH_ASSOC))
        {
          $mails[] = new Mail($donnees['mai_id'], $donnees['mai_sujet'],$donnees['mai_adresseMailDest'],
                              $donnees['mai_numDossier'], $donnees['mai_corpMess'], $donnees['mai_categorie'],
                              $donnee['mai_personne'],$donnees['mai_date']);
        }
     
        return $mails;
       }

    Merci d'avance pour m'aider a créer mon module de recherche

  2. #2
    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
    Par défaut
    je ne sais pas si c'est comme ça qu'il faut faire
    Pour le savoir, regarde la doc
    http://php.net/manual/fr/pdo.prepare.php

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $q = $this->db->prepare('SELECT * FROM mail WHERE mai_numDossier= :numDossier');
    $q->execute(array(':numDossier'=>$numDossier));
    Si ça ne fonctionne toujours pas, vérifie si au moins ta requête retourne un résultat, si ton rentre dans la boucle while, ce qui se passe dans ta classe Mail ... bref debugue un peu.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Juin 2016
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2016
    Messages : 60
    Par défaut
    J'ai tester ma requete dans phpmyadmin est ca me retourne des résultat, donc ma requete est bonne , après a voir dans ma fonction ...

  4. #4
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Juin 2016
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2016
    Messages : 60
    Par défaut
    J'ai mis dans ma fonction
    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
       public function rechercherMail($numDossier){
        $q = $this->db->prepare('SELECT * FROM mail WHERE mai_numDossier= :numDossier');
        $q->execute(array(':numDossier'=>$numDossier));
        $mails = [];
     
        while($donnees = $q->fetch(PDO::FETCH_ASSOC))
        {
          $mails[] = new Mail($donnees['mai_id'], $donnees['mai_sujet'],$donnees['mai_adresseMailDest'],
                              $donnees['mai_numDossier'], $donnees['mai_corpMess'], $donnees['mai_categorie'],
                              $donnee['mai_personne'],$donnees['mai_date']);
        }
     
        return $mails; echo "<pre>";
        var_dump($mails);  echo "</pre>"; die;exit; //ligne rajouter
       }
    Et le var_dump($mails) m'affiche bien les objets correspondant a la recherche...
    Mais m'indique
    Notice: Undefined variable: donnee

  5. #5
    Membre émérite
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2015
    Messages
    644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Novembre 2015
    Messages : 644
    Par défaut
    Citation Envoyé par nadgeul Voir le message
    J'ai mis dans ma fonction
    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
       public function rechercherMail($numDossier){
        $q = $this->db->prepare('SELECT * FROM mail WHERE mai_numDossier= :numDossier');
        $q->execute(array(':numDossier'=>$numDossier));
        $mails = [];
    
        while($donnees = $q->fetch(PDO::FETCH_ASSOC))
        {
          $mails[] = new Mail($donnees['mai_id'], $donnees['mai_sujet'],$donnees['mai_adresseMailDest'],
                              $donnees['mai_numDossier'], $donnees['mai_corpMess'], $donnees['mai_categorie'],
                              $donnee['mai_personne'],$donnees['mai_date']);
        }
        
        return $mails; echo "<pre>";
        var_dump($mails);  echo "</pre>"; die;exit; //ligne rajouter
       }
    Et le var_dump($mails) m'affiche bien les objets correspondant a la recherche...
    Mais m'indique Notice: Undefined variable: donnee
    Yop,

    Regarde la ligne que je t'ai mis en rouge

  6. #6
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Juin 2016
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2016
    Messages : 60
    Par défaut
    Ah oui en effet je ne trouvais pas on erreur Merci =)

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

Discussions similaires

  1. [MySQL] Formulaire de recherche sur mon site
    Par server.dbprod dans le forum PHP & Base de données
    Réponses: 0
    Dernier message: 07/07/2014, 11h34
  2. Réponses: 0
    Dernier message: 24/07/2013, 02h10
  3. Comment avoir le moteur de recherche google sur mon site
    Par l.laurent60 dans le forum Débuter
    Réponses: 1
    Dernier message: 18/01/2011, 22h29
  4. Problème insertion module Java sur mon site
    Par Sanoe dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 26/04/2010, 08h42
  5. Avoir la recherche Google sur mon site
    Par bruce-willis dans le forum Débuter
    Réponses: 4
    Dernier message: 23/02/2009, 13h54

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