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 :

Tableau croisé en PHP [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 36
    Par défaut Tableau croisé en PHP
    Bonjour à toutes et à tous,

    J'ai besoin de vos lumières pour la réalisation d'un tableau croisé en php.

    J'ai une requête SQL du type :

    Select ref, couleur, taille, quantité from produit where ref=$ref;

    J'aimerai faire un tableau qui contiendrait les tailles en lignes et les couleurs en colonnes et les données au milieu seraient les quantités.

    Pour l'instant mon tableau est comme ceci :



    Et je souhaiterai qu'il soit comme cela :



    Merci pour votre aide et à votre disposition si vous avez besoin de plus de renseignements.

  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 recoltes tes données en les classant par couleur et taille :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    while ($row = mysql_fetch_assoc($result)) {
       $tableau[$row['couleur']][$row['taille']] += $row['quantite'];
    }
    Tu n'as plus ensuite qu'a parcourir ce tableau avec foreach() pour dessiner ton tableau HMTL.

    Au passage tu n'as pas besoin de mettre ref dans ta liste de champs puisque c'est une valeur fixe.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 36
    Par défaut
    Super je crois que c'est en effet ce que je recherche.

    Par contre, n'étant pas très à l'aise avec le php, pourrais-tu me détailler le foreach ?

    Encore merci

  4. #4
    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
    C'est moi qui fait tout

    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
    $html_titre = '<tr><td>&nbsp;</td>';
    $html = '<table>';
    foreach ($tableau as $couleur=>$value) {
        $html_titre .= '<th>' . $couleur . '</th>';
        $html .= '<tr>';
        $new_line = TRUE;
        foreach ($value as $taille=>$quantite) {
               if ($new_line) {
                      $html .= '<td>' . $taille . '</td>';
                      $new_line = FALSE;
               }
               $html .= '<td>' . $quantite . '</td>';
        }
        $html .= '</tr>';
    }
    $html .= '</table>';
    $html_titre .= '</tr>';
     
    echo $html_titre . $htlml;
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 36
    Par défaut
    Merci beaucoup sabotage pour ton temps.

    Ca avance mais il reste plusieurs problèmes :

    Les tailles ne s'affiche pas correctement.


    Voici ce que ca m'affiche :




    Lorsqu'il y a plusieurs fois la même couleur, il faudrait qu'il ne l'affiche qu'une seule fois.

    Et voici mon code au complet :

    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
    <html>
    <body bgcolor=#9999FF>
    <?php 
    error_reporting(0);
    require_once('connect.php');
    echo '<br>';
    echo '<br>';
    echo '<br>';
    $ref=$_POST['ref'];
    $datemaj=$_POST['datemaj'];
    $requete='select reference,couleur,taille,quantite from produit where reference="'.$ref.'" ';
    $requete2='select distinct image from produit where reference="'.$ref.'" ';
    $result2=mysql_query($requete2) or die ("Pb requette ".mysql_error());
    $result=mysql_query($requete) or die ("Pb requette ".mysql_error());
    $list= mysql_fetch_array($result2);
    $pic= ('<img src="ImaPro/'.$list[0].'" height="180px" />'); 
     
    while ($row = mysql_fetch_assoc($result)) {
       $tableau[$row['taille']][$row['couleur']] += $row['quantite'];
    }
     
    $html_titre = '<tr><td>&nbsp;</td>';
    $html = '<table border=1>';
    foreach ($tableau as $taille=>$value) {
        $html_titre .= '<th>' . $taille . '</th>';
        $html .= '<tr>';
        $new_line = TRUE;
        foreach ($value as $couleur=>$quantite) {
               if ($new_line) {
                      $html .= '<td>' . $couleur . '</td>';
                      $new_line = FALSE;
               }
               $html .= '<td>' . $quantite . '</td>';
        }
        $html .= '</tr>';
    }
    $html .= '</table>';
    $html_titre .= '</tr>';
     
    echo $html_titre . $html;	
    echo '<br>';
     
    ?>
    </body>
    </html>

  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
    Par défaut
    C'est $result2 qui doit être recolté.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 36
    Par défaut
    result2 c'est juste pour récupérer les images associées aux produits mais je ne l'utilise pas encore.

  8. #8
    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
    ah oui pardon j'ai mal lu.

    Je rectifie :

    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
     
     
    $tblCouleur = array();
    while ($row = mysql_fetch_assoc($result)) {
       $tableau[$row['taille']][$row['couleur']] += $row['quantite'];
    if (!in_array($row['couleur'],$tblCouleur) { $tblCouleur[] = $row['couleur']; }
    }
     
    $html_titre = '<tr><td>&nbsp;</td>';
    $html = '<table border=1>';
    foreach ($tableau as $taille=>$value) {
        $html_titre .= '<th>' . $taille . '</th>';
        $html .= '<tr>';
        $new_line = TRUE;
        foreach ($tblCouleur as $couleur) {
               if ($new_line) {
                      $html .= '<td>' . $couleur . '</td>';
                      $new_line = FALSE;
               }
               $display = isset($value[$couleur]) ?   $value[$couleur] : "&nbsp;"; 
               $html .= '<td>' . $display . '</td>';
        }
        $html .= '</tr>';
    }
    $html .= '</table>';
    $html_titre .= '</tr>';
     
    echo $html_titre . $html;
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 36
    Par défaut
    Ca se précise !

    Mais j'ai toujours les tailles qui s'affiche en dehors du tableau et il m'affiche une seule couleur plusieurs fois même lorsqu'il est censé y avoir plusieurs couleurs.

    Voici ce que ça m'affiche :


  10. #10
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 36
    Par défaut
    Je pense avoir résolu le problème des tailles en mettant le <table> dans la variable $htmltitre plutôt que dans $html.

    Il me reste donc plus que 2 problèmes :

    - Les couleurs : le tableau n'affiche qu'une seule couleur et la répète plusieurs fois dans le tableau.

    - Les tailles : est-il possible de n'afficher les colonnes tailles seulement s'il y a une quantité correspondante ?


    Voici ton code que j'ai très légèrement modifié pour l'histoire des tailles en dehors du 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
    while ($row = mysql_fetch_assoc($result)) {
       $tableau[$row['taille']][$row['couleur']] += $row['quantite'];
    if (!in_array($row['couleur'],$tblCouleur)) { $tblCouleur[] = $row['couleur']; }
    }
     
    $html_titre = '<table border=1><tr><td>&nbsp;</td>';
    $html = '';
    foreach ($tableau as $taille=>$value) {
        $html_titre .= '<th>' . $taille . '</th>';
        $html .= '<tr>';
        $new_line = TRUE;
        foreach ($tblCouleur as $couleur) {
               if ($new_line) {
                      $html .= '<td>' . $couleur . '</td>';
                      $new_line = FALSE;
               }
               $display = isset($value[$couleur]) ?   $value[$couleur] : "&nbsp;"; 
               $html .= '<td>' . $display . '</td>';
        }
        $html .= '</tr>';
    }
    $html .= '</table>';
    $html_titre .= '</tr>';
     
    echo $html_titre . $html;

  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
    J'avais tout melangé :

    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
     
    echo '<table border="1">
             <tr>
                <th>&nbsp;</th>';
    foreach ($tblCouleur as $couleur) {
        echo '<th>' . htmlspecialchars($couleur) . '</th>';
    }
    echo '</tr>';
     
    foreach ($tableau as $taille=>$value) {
        echo '<tr>';
        $new_line = TRUE;
        foreach ($tblCouleur as $couleur) {
    	if ($new_line) {
                      echo '<td>' . $taille . '</td>';
                      $new_line = FALSE;
               }
     
               $display = isset($value[$couleur]) ?   $value[$couleur] : "&nbsp;"; 
               echo '<td>' . $display . '</td>';
        }
        echo '</tr>';
    }
    ?>
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  12. #12
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 36
    Par défaut
    Fantastique !

    C'est exactement ce que je cherchais et c'est pas évident de trouver un tutoriel pour faire ce genre de tableau

    Encore merci de ton aide

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

Discussions similaires

  1. [MySQL] tableau croisé en php
    Par guizaniseifislam dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 27/03/2013, 23h59
  2. parcourir un tableau croisé excel avec php
    Par ballantine's dans le forum Langage
    Réponses: 2
    Dernier message: 24/03/2010, 13h32
  3. [MySQL] [PHP/MySQL] Un tableau croisé [quasi] dynamique.
    Par Maljuna Kris dans le forum PHP & Base de données
    Réponses: 0
    Dernier message: 17/03/2009, 22h33

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