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 :

While imbriqué pour affichage de données [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 23
    Par défaut While imbriqué pour affichage de données
    j'aimerais faire un petit tableau de bord assez simple mais j'ai un problème avec l'affichage de mes données .

    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
     
    // requête qui prend tous les users de la session avec un niveau 4
    		$listetic = mysql_query("SELECT * FROM user WHERE id_entite='$sess_entite' AND niveau= '4' ") or die(mysql_error());
    		$listeticbis = mysql_query("SELECT * FROM user WHERE id_entite='$sess_entite' AND niveau= '4' ") or die(mysql_error());
    		// requête qui prend toutes les actions111 avec entité de la session
    		$liste = mysql_query("SELECT * FROM action111 WHERE id_entite='$sess_entite'") or die(mysql_error());
     
     
     
    		echo '<table>';
    		echo '<tr><td></td><td>Dates<td></td>';
     
    		while ($tic = mysql_fetch_array($listetic)) 				
    			{
    					$user = $tic['nom'];				
    					echo '<td>'. $user .'</td>';
    			}				
     
    				echo'<td>Avancement</td></tr>';
    				echo'<tr><td></td><td>Début</td><td>Fin</td></tr>';
     
    		while ($tic1 = mysql_fetch_array($listeticbis)) 				
    			{
    				$idtic = $tic1['id_user'];
     
     
    				while ($donnees = mysql_fetch_array($liste) )
     
    				{
    					$idaction = $donnees['id_action111'];
    					$titre = $donnees['titre_action111'];
    					$date_debut = $donnees['date_debut'];
    					$date_fin = $donnees['date_fin'];	
     
    					echo'<tr><td>'. $titre .'</td><td>'. $date_debut .'</td><td>'. $date_fin .'</td>';
    					$listeetat = mysql_query("SELECT * FROM action_en_cours WHERE id_action111='$idaction' AND id_user='$idtic'") or die(mysql_error());
     
    					while ($etatl = mysql_fetch_array($listeetat)) 
    						{
    							$etat = $etatl['etat'];
     
    							if ($etat == '0')
    								{
    									echo '<td>0</td>';
    								}
    							if ($etat == '1' )
    								{
    									echo '<td>1</td>';
    								}
    							else 
    								{
    								echo '<td>null</td>';
    								}
    						}
     
    				}
    				echo '</tr><tr>';
     
    			}
     
     
    			echo '</tr></table>';
    Le résultat donnée quand je test c'est qu'il ne m'affiche qu'une seule colonne avec des 0 et 1 et dans la deuxieme j'ai des null mais pas à toutes les lignes et puis des espaces blancs , ce qui ne devrait pas être normal
    Si vous pouviez jeter un coup d'oeil ça me ferait plaisir de résoudre ce problème que j'ai depuis hier

  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
    Tu as un problème d'ouverture/fermeture ici pour commencer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<tr><td></td><td>Dates<td></td>';
    Tu devrais valider ta page finale dans une verificateur HTML, il y a peut etre d'autres choses de cet acabit (ie : lignes de contenant pas le meme nombre de <td>).

    Pour le reste, pourquoi est-ce que tu boucles deux requetes identiques l'une dans l'autre ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 23
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $listetic = mysql_query("SELECT * FROM user WHERE id_entite='$sess_entite' AND niveau= '4' ") or die(mysql_error());
    		$listeticbis = mysql_query("SELECT * FROM user WHERE id_entite='$sess_entite' AND niveau= '4' ") or die(mysql_error());
    tu parles sans doute de ça ... Bah figures toi que j'ai testé et rien ne marchait à vrai dire , à part ça

    Sinon je vais voir pour les td mais il me semble qu'il y a effectivement autre chose comme erreur

  4. #4
    Membre averti
    Inscrit en
    Décembre 2002
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Décembre 2002
    Messages : 53
    Par défaut
    Pour avoir une bonne mise en forme, essaye d'abord de le créer un template (uniquement en HTML). Créer le tableau avec des données fictive sans te soucier de la logique php. Une fois que tu as la présentation voulue, intègre la dans le code PHP.
    Je trouve que c'est plus simple que de vouloir d'un seul coup régler un problème HTML et PHP en même temps. Et puis évite un peu les syntaxes dans le genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<td></td><td>Dates</td>';
    préfère plutôt
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    <?php 
        // ton code php ici 
    ?>
    <td></td><td>Dates</td> <!-- du code html sans "echo" -->
    <?php 
       // la suite de ton code php ici 
    ?>
    Cela rendra ton code plus lisible et plus facile à comprendre.
    A+

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 23
    Par défaut
    Merci pour vos réponses !
    Le problème c'est que je ne peux pas savoir le nombre de colonnes que je vais avoir !
    Donc je fais un <td></td> à chaque entré

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<tr><td></td><td>Dates<td></td>';
    ceci n'est pas correct même si je fais des echo derrière pour fermer les balises ?

    PS : j'ai corrigé en effet ces balises

  6. #6
    Membre averti
    Inscrit en
    Décembre 2002
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Décembre 2002
    Messages : 53
    Par défaut
    si tu fermes bien toutes les balises que tu ouvres, c'est correcte. Seulement c'est très optimal car si tu fais des "echo" pour n'afficher que du HTML tu vas faire travailler le serveur un peu plus alors qu'il se serait contenter d'envoyer tout simplement le HTML vers le client.

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

Discussions similaires

  1. Conception pour affichage de données arborescentes
    Par vinzzzz dans le forum Général Java
    Réponses: 0
    Dernier message: 26/10/2009, 19h42
  2. Réponses: 9
    Dernier message: 04/02/2009, 22h50
  3. problème pour affichage de données
    Par FraK dans le forum Langage
    Réponses: 6
    Dernier message: 07/03/2007, 15h38
  4. [MySQL] Aide pour affichage de donné recup dans une BD
    Par mitchb dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 18/05/2006, 11h38
  5. Réponses: 3
    Dernier message: 11/01/2006, 17h44

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