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 :

Problèmes affichage avec tableau


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2017
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2017
    Messages : 60
    Points : 21
    Points
    21
    Par défaut Problèmes affichage avec tableau
    Bonjour,

    J’ai un soucis dans mon code qui n’affiche pas les données de ma variable $name dans mon tableau html.
    Et mon tableau est tout simplement inexistant donc même les entêtes ne s’affiche pas et cela sans raisons !

    Le code de la page contenant le tableau :
    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
     <?php
    			require('conditions.php');
    		?>
    <div class="employees">
    	<table>
    		<thead>
    			<tr>
    				<?php
    					if ($all['fonction'] == "1") {
    						echo '<th>Pharmaciens</th>';
    					}
     
    					if ($all['fonction'] == "2") {
    						echo '<th>Préparateurs/trices</th>';
    					}
     
    					if ($all['fonction'] == "3") {
    						echo '<th>Fonction1</th>';
    					}
     
    					if ($all['fonction'] == "4") {
    						echo '<th>Secrétaires</th>';
    					}
     
    					if ($all['fonction'] == "5") {
    						echo '<th>Agents d’entretien</th>';
    					}
    				?>
    			</tr>
    		</thead>
    		<tbody>
    			<tr>
    				<?php
    					if ($all['fonction'] == "1") {
    						echo '<td>'. $pharmaciens['name'] .'</td>';
    					} 			
     
    					if ($all['fonction'] == "2") {
    						echo '<td>'. $preparateurs['name'] .'</td>';
    					}
     
    					if ($all['fonction'] == "3") {
    						echo '<td>'. $fonction1['name'] .'</td>';
    					}
     
    					if ($all['fonction'] == "4") {
    						echo '<td>'. $secretaires['name'] .'</td>';
    					}
     
    					if ($all['fonction'] == "5") {
    						echo '<td>'. $agents['name'] .'</td>';
    					}
    				?>
    			</tr>
    		</tbody>					
    	</table>
    </div>
    Voici le code de la page conditions.php :
    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
    <?php
    $bdd = new PDO('mysql:host=localhost;dbname=Dbname', 'user', 'pass');
    $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
     
       $reqall= $bdd->prepare('SELECT * FROM employees');
       $all = $reqall->fetch();
     
       $reqpharmaciens= $bdd->prepare('SELECT * FROM employees WHERE fonction = "1" ');
       $pharmaciens = $reqpharmaciens->fetch();
     
      $reqpreparateurs= $bdd->prepare('SELECT * FROM employees WHERE fonction = "2" ');
      $preparateurs = $reqpreparateurs->fetch();
     
      $reqsecretaires= $bdd->prepare('SELECT * FROM employees WHERE fonction = "3" ');
      $secretaires = $reqsecretaires->fetch();
     
      $reqfonction1= $bdd->prepare('SELECT * FROM employees WHERE fonction = "4" ');
      $fonction1 = $reqfonction1->fetch();
     
      $reqagents= $bdd->prepare('SELECT * FROM employees WHERE fonction = "5" ');
      $agents = $reqagents->fetch();
    ?>
    Merci d’avance pour votre aide

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    en fait ton code est catastrophique donc c'est une bonne chose qu'il ne fonctionne pas

    Déjà fais une table qui liste les fonctions
    fonction_id, fonction_name
    1 Pharmaciens
    2 Préparateurs/trices
    ....

    Comme ça tu fais une jointure entre ta table de personnes et ta table de fonctions

    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
     
    $bdd = new PDO('mysql:host=localhost;dbname=Dbname', 'user', 'pass');
    $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
     
    $sth= $bdd->query('SELECT employees.name as employee_name, fonction_name as fonction_name FROM employees JOIN fonctions ON employees.fonction = fonction_id');
     
    // tu ranges toutes les personnes par fonction
    while ($row = $th->fetch(PDO:FETCH_ASSOC)) {
        $result[$row['fonction_name']][] = $row['employee_name'];
    }
     
    $nligne = 0;
     
    echo '<table>
                 <tr>';
     
    // pour chaque fonction on affiche une en tête de colonne
    foreach ($result as $fonction_name => $values) {
          echo '<th>' . $fonction_name . '</th>';
          // on compte le nombre maximal de lignes que devra avoir notre tableau
          $nligne = max($nligne, count($values);
    }
    echo '</tr>';
     
    // pour chaque ligne
    for ($l = 0; $l < $nligne; ++$l) {
        echo '<tr>';
        // on parcours les fonctions et on affiche la personne si elle existe pour cette ligne
        foreach ($result as $fonction_name => $values) {
            $display = (isset($values[$l])) ? $values[$l] : '';
             echo '<td>' . $display . '</td>';
        }
       echo '</tr>';
    }
    echo '</table>';
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre à l'essai
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2017
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2017
    Messages : 60
    Points : 21
    Points
    21
    Par défaut
    Merci beaucoup Sabotage ça fonctionne super bien (je me remet au code après 1 an de sommeil )

    Par contre je n'ai jamais trouvé de moyen quelconque pour aligner les tableaux avec leurs entêtes de façon verticale. Par exemple que les Pharmaciens soit en haut et les préparateurs en dessous ? Si quelqu'un connait l'astuce, je suis preneur.

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre à l'essai
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2017
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2017
    Messages : 60
    Points : 21
    Points
    21
    Par défaut
    D’accord, merci

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

Discussions similaires

  1. [X3-V6] Problème affichage champs tableau avec liste détail
    Par Arkhana dans le forum SAGE
    Réponses: 29
    Dernier message: 29/08/2016, 10h41
  2. Problème affichage avec ATI Mobility FireGL v3200
    Par MoDDiB dans le forum NxEngine
    Réponses: 2
    Dernier message: 25/06/2007, 09h33
  3. Problème site avec tableau
    Par liljerem dans le forum Balisage (X)HTML et validation W3C
    Réponses: 14
    Dernier message: 07/06/2007, 18h51
  4. Problème affichage avec MSN
    Par CLion dans le forum Messagerie instantanée
    Réponses: 4
    Dernier message: 11/12/2006, 16h45
  5. [PHP-JS] Problème affichage avec structure if
    Par kitty2006 dans le forum Langage
    Réponses: 31
    Dernier message: 07/09/2006, 18h01

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