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

  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.

  7. #7
    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
    Oui normalement j'ai tout bien ouvert et tout bien fermé

    Je vous ai fais un petit imprim écran du résultat que je vois en pièce jointe.

    Donc je comprends pas comment il fait pour aller à la seconde colonne (nomtech 3 - avec des null et pas remplir la ligne du milieu ) et qu'il ne termine pas avec la colonne nomtech4
    Images attachées Images attachées  

  8. #8
    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
    J'ai un problème avec ça depuis 3 jours maintenant et ça commence à bien me
    Je dois afficher un tableau de résultat ( un tableau de récap ) , et donc avec un nombre de lignes et de colonne dynamique selon la BD .
    Donc par lignes des actions et par colonnes des techniciens ( + des petits trucs genre des dates mais c'est easy ça au moins :'( ).
    Donc j'aimerai que pour chaque ligne on regarde si le technicien a un état 0 ou 1 ou rien et afficher cet état dans la case correspondante .
    Donc il faut une double boucle et malheureusement je sais pas comment c'est foutu mais c'est mal foutu ... Je n'affiche que la première ligne du traitement et ça va pas à la ligne. Je vois où est mon erreur mais ... je n'arrives pas à la corriger.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    // 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());

    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
    echo '<table>';
    		echo '<tr><td></td><td></td><td>Dates</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 ($donnees = mysql_fetch_array($liste) )
     
       {
     
         $idaction = $donnees['id_action111'];
         $titre = $donnees['titre_action111'];
         $date_debut = $donnees['date_debut'];
         $date_fin = $donnees['date_fin'];
    // echo "$idaction<br/>" ===========> ça marche j'ai bien ma liste d'id action
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
         echo'<tr><td>'. $titre .'</td><td>'. $date_debut .'</td><td>'. $date_fin .'</td>';  
     
            while ($tic1 = mysql_fetch_array($listeticbis))     
            {
     
                $idtic = $tic1['id_user'];
    // echo "$idaction<br/>"; ====> ça m'affiche que la première action
    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
     
    $listeetat = mysql_query("SELECT * FROM action_en_cours WHERE id_action111='$idaction' AND id_user='$idtic'") or die(mysql_error());
    				$etatl = mysql_fetch_array($listeetat);
     
                    $etat = $etatl['etat'];     
                    if ($etat == '0')
                    {
                        echo '<td>0</td>';
     
                    } else {
     
    					if ($etat == '1' )
                            {
                                echo '<td>1</td>';
                            } else {
                                echo '<td>null</td>';
                            }
     
    						}
     
     
            }
     
     
            echo '</tr>';
       }
     
       echo '</table>';
    Donc voilà mon problème je n'arrives pas à faire changer l'id action pour changer de ligne
    Aidez moi s'il vous plait

  9. #9
    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
    Donne nous un dump de tes tables, ca sera plus facile pour t'aider.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  10. #10
    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
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    CREATE TABLE IF NOT EXISTS `action111` (
      `id_action111` int(11) NOT NULL AUTO_INCREMENT,
      `titre_action111` varchar(80) NOT NULL DEFAULT '',
      `declinaison` enum('NULL','OUI','NON') NOT NULL DEFAULT 'OUI',
      `nom_porteur` varchar(30) NOT NULL DEFAULT '',
      `date_debut` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
      `date_fin` datetime DEFAULT '0000-00-00 00:00:00',
      `indicateur` mediumtext,
      `id_entite` int(11) DEFAULT NULL,
      `action_mere` int(11) NOT NULL DEFAULT '0',
      `indic_couleur` int(11) DEFAULT NULL,
      PRIMARY KEY (`id_action111`),
      KEY `id_entite` (`id_entite`),
      KEY `action_mere` (`action_mere`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=54 ;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    CREATE TABLE IF NOT EXISTS `action_en_cours` (
      `id_action1` int(11) DEFAULT '0',
      `id_action11` int(11) DEFAULT '0',
      `id_action111` int(11) DEFAULT '0',
      `id_user` int(11) NOT NULL DEFAULT '0',
      `etat` int(11) NOT NULL DEFAULT '0',
      `id_action_en_cours` int(11) NOT NULL AUTO_INCREMENT,
      PRIMARY KEY (`id_action_en_cours`),
      KEY `id_action1` (`id_action1`),
      KEY `id_action11` (`id_action11`),
      KEY `id_action111` (`id_action111`),
      KEY `id_user` (`id_user`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=80 ;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    CREATE TABLE IF NOT EXISTS `entite` (
      `id_entite` int(11) NOT NULL AUTO_INCREMENT,
      `nom_entite` varchar(50) NOT NULL DEFAULT '',
      `mere_entite` varchar(50) NOT NULL DEFAULT '',
      PRIMARY KEY (`id_entite`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=9 ;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    CREATE TABLE IF NOT EXISTS `user` (
      `id_user` int(11) NOT NULL AUTO_INCREMENT,
      `nom` varchar(30) NOT NULL DEFAULT '',
      `prenom` varchar(30) NOT NULL DEFAULT '',
      `login` varchar(30) NOT NULL DEFAULT '',
      `pass` varchar(30) NOT NULL DEFAULT '',
      `id_chef` int(11) DEFAULT '0',
      `niveau` int(11) DEFAULT '0',
      `id_entite` int(11) NOT NULL DEFAULT '0',
      PRIMARY KEY (`id_user`),
      KEY `id_chef` (`id_chef`),
      KEY `id_entite` (`id_entite`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=16 ;

  11. #11
    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
    avec quelques lignes de données sinon on peut pas tester
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  12. #12
    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
    Je vous donnes tout , car j'ai peur qu'il y ai des contraintes lié au clés étrangères , j'espère que ça vous aidera à m'aider

    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
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    -- phpMyAdmin SQL Dump
    -- version 3.1.3.1
    -- http://www.phpmyadmin.net
    --
    -- Serveur: localhost
    -- Généré le : Sam 22 Août 2009 à 12:21
    -- Version du serveur: 5.1.33
    -- Version de PHP: 5.2.9-2
     
    SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
     
    --
    -- Base de données: `planaction`
    --
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `action1`
    --
     
    CREATE TABLE IF NOT EXISTS `action1` (
      `id_action` int(11) NOT NULL AUTO_INCREMENT,
      `titre_action` varchar(80) NOT NULL DEFAULT '',
      `commentaire1` mediumtext,
      `declinaison` enum('NULL','OUI','NON') NOT NULL DEFAULT 'OUI',
      `nom_porteur` varchar(30) NOT NULL DEFAULT '',
      `date_debut` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
      `date_fin` datetime DEFAULT '0000-00-00 00:00:00',
      `indicateur` mediumtext,
      `id_entite` int(11) DEFAULT NULL,
      PRIMARY KEY (`id_action`),
      KEY `id_entite` (`id_entite`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=56 ;
     
    --
    -- Contenu de la table `action1`
    --
     
    INSERT INTO `action1` (`id_action`, `titre_action`, `commentaire1`, `declinaison`, `nom_porteur`, `date_debut`, `date_fin`, `indicateur`, `id_entite`) VALUES
    (53, 'titre', '', 'NULL', 'CdD_QPERF', '0000-00-00 00:00:00', '0000-00-00 00:00:00', '', 5),
    (54, 'titre', '', 'OUI', 'CdD_INTGP', '0000-00-00 00:00:00', '0000-00-00 00:00:00', '', 6),
    (55, 'titre123', '', 'OUI', 'CdD_INTGP', '0000-00-00 00:00:00', '0000-00-00 00:00:00', '', 6);
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `action11`
    --
     
    CREATE TABLE IF NOT EXISTS `action11` (
      `id_action11` int(11) NOT NULL AUTO_INCREMENT,
      `titre_action11` varchar(80) NOT NULL DEFAULT '',
      `indic_couleur` int(11) DEFAULT NULL,
      `declinaison` enum('NULL','OUI','NON') NOT NULL DEFAULT 'OUI',
      `nom_porteur` varchar(30) NOT NULL DEFAULT '',
      `date_debut` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
      `date_fin` datetime DEFAULT '0000-00-00 00:00:00',
      `indicateur` mediumtext,
      `id_entite` int(11) DEFAULT NULL,
      `action_mere` int(11) NOT NULL DEFAULT '0',
      `commentaire11` mediumtext,
      PRIMARY KEY (`id_action11`),
      KEY `id_entite` (`id_entite`),
      KEY `action_mere` (`action_mere`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=76 ;
     
    --
    -- Contenu de la table `action11`
    --
     
    INSERT INTO `action11` (`id_action11`, `titre_action11`, `indic_couleur`, `declinaison`, `nom_porteur`, `date_debut`, `date_fin`, `indicateur`, `id_entite`, `action_mere`, `commentaire11`) VALUES
    (73, 'titre', NULL, 'NULL', 'CdD_QPERF', '0000-00-00 00:00:00', '0000-00-00 00:00:00', NULL, 5, 54, NULL),
    (74, 'titre', NULL, 'OUI', 'CdD_INTGP', '0000-00-00 00:00:00', '0000-00-00 00:00:00', NULL, 6, 54, NULL),
    (75, 'titre123', NULL, 'OUI', 'CdD_INTGP', '0000-00-00 00:00:00', '0000-00-00 00:00:00', NULL, 6, 55, NULL);
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `action111`
    --
     
    CREATE TABLE IF NOT EXISTS `action111` (
      `id_action111` int(11) NOT NULL AUTO_INCREMENT,
      `titre_action111` varchar(80) NOT NULL DEFAULT '',
      `declinaison` enum('NULL','OUI','NON') NOT NULL DEFAULT 'OUI',
      `nom_porteur` varchar(30) NOT NULL DEFAULT '',
      `date_debut` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
      `date_fin` datetime DEFAULT '0000-00-00 00:00:00',
      `indicateur` mediumtext,
      `id_entite` int(11) DEFAULT NULL,
      `action_mere` int(11) NOT NULL DEFAULT '0',
      `indic_couleur` int(11) DEFAULT NULL,
      PRIMARY KEY (`id_action111`),
      KEY `id_entite` (`id_entite`),
      KEY `action_mere` (`action_mere`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=54 ;
     
    --
    -- Contenu de la table `action111`
    --
     
    INSERT INTO `action111` (`id_action111`, `titre_action111`, `declinaison`, `nom_porteur`, `date_debut`, `date_fin`, `indicateur`, `id_entite`, `action_mere`, `indic_couleur`) VALUES
    (51, 'titre', 'OUI', 'CdG_NICE1', '0000-00-00 00:00:00', '0000-00-00 00:00:00', NULL, 1, 74, 0),
    (52, 'titre', 'NULL', 'CdG_NICE2', '0000-00-00 00:00:00', '0000-00-00 00:00:00', NULL, 2, 74, 0),
    (53, 'titre123', 'OUI', 'CdG_NICE1', '0000-00-00 00:00:00', '0000-00-00 00:00:00', NULL, 1, 75, 0);
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `action_en_cours`
    --
     
    CREATE TABLE IF NOT EXISTS `action_en_cours` (
      `id_action1` int(11) DEFAULT '0',
      `id_action11` int(11) DEFAULT '0',
      `id_action111` int(11) DEFAULT '0',
      `id_user` int(11) NOT NULL DEFAULT '0',
      `etat` int(11) NOT NULL DEFAULT '0',
      `id_action_en_cours` int(11) NOT NULL AUTO_INCREMENT,
      PRIMARY KEY (`id_action_en_cours`),
      KEY `id_action1` (`id_action1`),
      KEY `id_action11` (`id_action11`),
      KEY `id_action111` (`id_action111`),
      KEY `id_user` (`id_user`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=80 ;
     
    --
    -- Contenu de la table `action_en_cours`
    --
     
    INSERT INTO `action_en_cours` (`id_action1`, `id_action11`, `id_action111`, `id_user`, `etat`, `id_action_en_cours`) VALUES
    (NULL, NULL, 51, 11, 0, 74),
    (NULL, NULL, 51, 13, 0, 75),
    (NULL, NULL, 51, 15, 1, 76),
    (NULL, NULL, 53, 11, 0, 77),
    (NULL, NULL, 53, 13, 0, 78),
    (NULL, NULL, 53, 15, 0, 79);
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `entite`
    --
     
    CREATE TABLE IF NOT EXISTS `entite` (
      `id_entite` int(11) NOT NULL AUTO_INCREMENT,
      `nom_entite` varchar(50) NOT NULL DEFAULT '',
      `mere_entite` varchar(50) NOT NULL DEFAULT '',
      PRIMARY KEY (`id_entite`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=9 ;
     
    --
    -- Contenu de la table `entite`
    --
     
    INSERT INTO `entite` (`id_entite`, `nom_entite`, `mere_entite`) VALUES
    (1, 'NICE 1', 'INTGP'),
    (2, 'NICE2', 'INTGP'),
    (3, 'Saint-Laurent', 'INTGP'),
    (4, 'Cannes', 'INTGP'),
    (5, 'QPERF', 'CODUI'),
    (6, 'INTGP', 'CODUI'),
    (7, 'ICER', 'CODUI'),
    (8, 'CABL', 'CODUI');
     
    -- --------------------------------------------------------
     
    --
    -- Structure de la table `user`
    --
     
    CREATE TABLE IF NOT EXISTS `user` (
      `id_user` int(11) NOT NULL AUTO_INCREMENT,
      `nom` varchar(30) NOT NULL DEFAULT '',
      `prenom` varchar(30) NOT NULL DEFAULT '',
      `login` varchar(30) NOT NULL DEFAULT '',
      `pass` varchar(30) NOT NULL DEFAULT '',
      `id_chef` int(11) DEFAULT '0',
      `niveau` int(11) DEFAULT '0',
      `id_entite` int(11) NOT NULL DEFAULT '0',
      PRIMARY KEY (`id_user`),
      KEY `id_chef` (`id_chef`),
      KEY `id_entite` (`id_entite`)
    ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=16 ;
     
    --
    -- Contenu de la table `user`
    --
     
    INSERT INTO `user` (`id_user`, `nom`, `prenom`, `login`, `pass`, `id_chef`, `niveau`, `id_entite`) VALUES
    (1, 'directeur', 'prenom_1', 'login_1', 'pass_1', NULL, 1, 0),
    (2, 'nom_2', 'prenom_2', 'login_2', 'pass_2', 1, 2, 0),
    (3, 'CdD_QPERF', 'prenom_3', 'login_3', 'pass_3', 1, 2, 5),
    (4, 'CdD_INTGP', 'prenom_4', 'login_4', 'pass_4', 1, 2, 6),
    (5, 'CdD_ICER', 'prenom_5', 'login_5', 'pass_5', 1, 2, 7),
    (7, 'CdG_NICE1', 'prenomB', 'login_A', 'pass_A', 4, 3, 1),
    (8, 'CdG_NICE2', 'prenom_B', 'login_B', 'pass_B', 4, 3, 2),
    (9, 'CdG_St-LAURENT', 'prenom_C', 'login_C', 'pass_C', 4, 3, 3),
    (10, 'CdG_CANNES', 'prenom_D', 'login_D', 'pass_D', 4, 3, 4),
    (11, 'nomtech1', 'prenomtech1', 'login_T1', 'pass_T1', 7, 4, 1),
    (12, 'nomtech2', 'prenomtech2', 'login_T2', 'pass_T2', 8, 4, 2),
    (13, 'nomtech3', 'prenom_1', 'login_T3', 'pass_T3', 7, 4, 1),
    (14, 'CdD_CABL', 'prenom_6', 'login_6', 'pass_6', 1, 2, 8),
    (15, 'nomtech4', 'prenomtech', 'blabla', 'blabla', 7, 4, 1);
     
    --
    -- Contraintes pour les tables exportées
    --
     
    --
    -- Contraintes pour la table `action1`
    --
    ALTER TABLE `action1`
      ADD CONSTRAINT `action1_ibfk_1` FOREIGN KEY (`id_entite`) REFERENCES `entite` (`id_entite`) ON DELETE CASCADE ON UPDATE CASCADE;
     
    --
    -- Contraintes pour la table `action11`
    --
    ALTER TABLE `action11`
      ADD CONSTRAINT `action11_ibfk_1` FOREIGN KEY (`id_entite`) REFERENCES `entite` (`id_entite`) ON DELETE CASCADE ON UPDATE CASCADE,
      ADD CONSTRAINT `action11_ibfk_2` FOREIGN KEY (`action_mere`) REFERENCES `action1` (`id_action`) ON DELETE CASCADE ON UPDATE CASCADE;
     
    --
    -- Contraintes pour la table `action111`
    --
    ALTER TABLE `action111`
      ADD CONSTRAINT `action111_ibfk_1` FOREIGN KEY (`id_entite`) REFERENCES `entite` (`id_entite`) ON DELETE CASCADE ON UPDATE CASCADE,
      ADD CONSTRAINT `action111_ibfk_2` FOREIGN KEY (`action_mere`) REFERENCES `action11` (`id_action11`) ON DELETE CASCADE ON UPDATE CASCADE;
     
    --
    -- Contraintes pour la table `action_en_cours`
    --
    ALTER TABLE `action_en_cours`
      ADD CONSTRAINT `action_en_cours_ibfk_1` FOREIGN KEY (`id_action1`) REFERENCES `action1` (`id_action`) ON DELETE CASCADE ON UPDATE CASCADE,
      ADD CONSTRAINT `action_en_cours_ibfk_2` FOREIGN KEY (`id_action11`) REFERENCES `action11` (`id_action11`) ON DELETE CASCADE ON UPDATE CASCADE,
      ADD CONSTRAINT `action_en_cours_ibfk_3` FOREIGN KEY (`id_action111`) REFERENCES `action111` (`id_action111`) ON DELETE CASCADE ON UPDATE CASCADE,
      ADD CONSTRAINT `action_en_cours_ibfk_4` FOREIGN KEY (`id_user`) REFERENCES `user` (`id_user`) ON DELETE CASCADE ON UPDATE CASCADE;
     
    --
    -- Contraintes pour la table `user`
    --
    ALTER TABLE `user`
      ADD CONSTRAINT `user_ibfk_1` FOREIGN KEY (`id_chef`) REFERENCES `user` (`id_user`) ON DELETE CASCADE ON UPDATE CASCADE;

  13. #13
    Membre émérite Avatar de micetf
    Homme Profil pro
    Professeur des Ecoles
    Inscrit en
    Mai 2009
    Messages
    557
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ardèche (Rhône Alpes)

    Informations professionnelles :
    Activité : Professeur des Ecoles
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2009
    Messages : 557
    Par défaut
    Voici une proposition juste pour aider,
    si ça ne convient pas oubliez vite.

    Personnellement,
    j'aurais codé ça de cette manière,
    parce que ça me parait plus simple à déboguer :
    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
    <?php 
    // 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());
     
    // 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());
    ?>
    <table>
     
    <!-- #################### Première ligne du tableau ################################-->
    <tr>
    	<td></td>
    	<td></td>
    	<td>Dates</td>
    <?php
    	$idsTic = array();
    	while ($tic = mysql_fetch_array($listetic)) {
    		$user = $tic['nom'];    
            $idsTic[] = $tic['id_user'];
    ?>
    	<!-- #################### Non du technicien ################################-->
    	<td><?php echo $user; ?></td>
    <?php 
    	}
    ?>
    	<td>Avancement</td>
    </tr>
     
    <!-- #################### Deuxième ligne du tableau ################################-->
    <tr>
    	<td></td>
    	<td>Début</td>
    	<td>Fin</td>
    </tr>
     
    <?php 
        while ($donnees = mysql_fetch_array($liste) ) {
    		$idaction = $donnees['id_action111'];
    		$titre = $donnees['titre_action111'];
    		$date_debut = $donnees['date_debut'];
    		$date_fin = $donnees['date_fin'];
    ?>
    <!-- #################### Un ligne par action ################################-->
    <tr>
    	<td><?php echo $titre; ?></td>
    	<td><?php echo $date_debut; ?></td>
    	<td><?php echo $date_fin; ?></td>
    <?php   
    		foreach ($idsTic as $idTic) {
    			$listeetat = mysql_query("SELECT * FROM action_en_cours WHERE id_action111='$idaction' AND id_user='$idtic'") or die(mysql_error());
    			$etatl = mysql_fetch_array($listeetat);
    			$etat = ($etatl['etat'] == '0' || $etatl['etat'] == '1') ? $etat1['etat'] : 'null';     
    ?>
    	<!-- #################### Un etat par technicien ################################-->
    	<td><?php echo $etat; ?></td>
    <?php 
    		}
    ?>
    </tr>
    <?php 
    	}
    ?>
     
    </table>
    Fred

  14. #14
    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
    il semblerait que ça marche , merci fred
    je le mets en résolu , merci pour vos aides

  15. #15
    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
    Comme j'ai ecris un truc je le mets aussi.

    Il a l'avantage de bien separer les données et l'affichage, et de ne faire que 3 accès à la base.

    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
     
    $result = mysql_query("SELECT * FROM user WHERE id_entite=1 AND niveau=4 ") or die(mysql_error());
    while ($row = mysql_fetch_assoc($result))     
    {
    $aTech[$row['id_user']] = $row['nom'];
    }
     
    $result = mysql_query("SELECT id_action111, titre_action111, date_debut, date_fin FROM action111 WHERE id_entite=1") or die(mysql_error());
    while ($row = mysql_fetch_assoc($result))     
    {
    $aActions[$row['id_action111']] = $row;
    }
     
    $result = mysql_query("SELECT id_action111, id_user, etat  FROM action_en_cours JOIN action111 USING (id_action111) WHERE id_entite=1") or die(mysql_error());
    while ($row = mysql_fetch_assoc($result))     
    {
    $aEncours[$row['id_action111']][$row['id_user']] = $row['etat'];
    }
     
    echo '<table border="1">';
    		echo '<tr>
    			<td colspan="2"</td>
    			<td>Dates</td>';
     
    		foreach($aTech as $nom)
    		{
    		echo '<td>'. $nom .'</td>';
    		}    
     
    		echo'	<td>Avancement</td>
    			</tr>';
    		echo'<tr>
    				<td></td>
    				<td>Début</td>
    				<td>Fin</td>
    			</tr>';
     
     
    	foreach($aActions as $donnees)  {
    		$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>';
    		foreach ($aTech as $id=>$nom) {
    			if (isset($aEncours[$idaction][$id])) {
    			   $etat = $aEncours[$idaction][$id]['etat'];
    			}
    			else {
    				$etat = '&nbsp;';
    			}
    		 echo '<td>' . $etat . '</td>';
    		}
    		echo '</tr>';
    	}
    echo '</table>';
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

+ 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, 20h42
  2. Réponses: 9
    Dernier message: 04/02/2009, 23h50
  3. problème pour affichage de données
    Par FraK dans le forum Langage
    Réponses: 6
    Dernier message: 07/03/2007, 16h38
  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, 12h38
  5. Réponses: 3
    Dernier message: 11/01/2006, 18h44

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