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

Langage PHP Discussion :

Tableau avec requêtes sql


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2013
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 120
    Points : 53
    Points
    53
    Par défaut Tableau avec requêtes sql
    Bonjour,

    Je viens vous demander de l'aide car je dois mettre en forme un tableau de cette forme :

    http://img4.hostingpics.net/pics/762113fdf.jpg

    Le problème, est que dans ce tableau, beaucoup de valeurs sont entrées en dur, car je n'arrive pas à mettre en ordre les résultats de mes requêtes.

    Voila comment je forme mon 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
    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
     
     <TR> 
     <TH> Organisme Complémentaire </TH> 
     <TH> Contrat </TH> 
     <!-- On affiche la liste des services -->
     <?php
     
    while($data2 = mysql_fetch_assoc($req2))
    {
    $services = $data2['SER_nom'];
    echo'<TH>';
    echo $services;
    echo '</TH>';
    }
     
    ?>
     <TH> Montant annuel </TH> 
     <TH> Reste à charge annuel </TH> 
     <TH> Reste à charge mensuel </TH> 
      </TR> 
    ------------------------------------------------------------------------------------------------------------------
    //PREMIERE LIGNE
    while($i < 10){
     
     
    if ($i==0){
    echo'<TR>';echo'<TH>';
    echo 'APREVA';
    echo '</TH>';}
    else if ($i ==1){
    echo '<TD>'; echo 'ACS'; echo '</TD>';
    }
    else if ($i!=0 && $i!=1 && $i!=6 && $i!=7 && $i!=8){
    while ($data4 = mysql_fetch_assoc($req4)){
    echo '<TD>'; echo $data4['VSO_valeur']; echo '</TD>';
    }}
    else if ($i==6)
    {
    echo '<TD>'; echo '672€'; echo '</TD>';
    }
    else if ($i==7)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    else if ($i==8)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    $i++;
    }
    echo'</TR>';
     
    $i=0;
    //-----------------------------------------------------------------------------------------------------------------------------
    //DEUXIEME LIGNE
    while($i < 10){
    if ($i==0){
    echo'<TR>';echo'<TH>';
    echo 'LIBRE CHOIX';
    echo '</TH>';}
    else if ($i ==1){
    echo '<TD>'; echo 'Emeraude'; echo '</TD>';
    }
    else if ($i!=0 && $i!=1 && $i!=6 && $i!=7 && $i!=8){
    while ($data5 = mysql_fetch_assoc($req5)){
    echo '<TD>'; echo $data5['VSO_valeur']; echo '</TD>';
    }}
    else if ($i==6)
    {
    echo '<TD>'; echo '648€'; echo '</TD>';
    }
    else if ($i==7)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    else if ($i==8)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    $i++;
    }
    echo'</TR>';
     
    $i=0;
     
    //-----------------------------------------------------------------------------------------------------------------------------
    //TROISIEME LIGNE
     
    while($i < 10){
    if ($i==0){
    echo'<TR>';echo'<TH>';
    echo 'JUST EN FAMILLE';
    echo '</TH>';}
    else if ($i ==1){
    echo '<TD>'; echo 'Modulo Actif Base/N1'; echo '</TD>';
    }
    else if ($i!=0 && $i!=1 && $i!=6 && $i!=7 && $i!=8){
    while ($data6 = mysql_fetch_assoc($req6)){
    echo '<TD>'; echo $data6['VSO_valeur']; echo '</TD>';
    }}
    else if ($i==6)
    {
    echo '<TD>'; echo '755.64€'; echo '</TD>';
    }
    else if ($i==7)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    else if ($i==8)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    $i++;
    }
    echo'</TR>';
     
    $i=0;
     
    //-----------------------------------------------------------------------------------------------------------------------------
    //QUATRIEME LIGNE
    while($i < 10){
    if ($i==0){
    echo'<TR>';echo'<TH>';
    echo 'ALLIANZ';
    echo '</TH>';}
    else if ($i ==1){
    echo '<TD>'; echo 'H2O2D2'; echo '</TD>';
    }
    else if ($i!=0 && $i!=1 && $i!=6 && $i!=7 && $i!=8){
    while ($data7 = mysql_fetch_assoc($req7)){
    echo '<TD>'; echo $data7['VSO_valeur']; echo '</TD>';
    }}
    else if ($i==6)
    {
    echo '<TD>'; echo '989.79€'; echo '</TD>';
    }
    else if ($i==7)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    else if ($i==8)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    $i++;
    }
    echo'</TR>';
     
    $i=0;
     
    //-----------------------------------------------------------------------------------------------------------------------------
    //CINQUIEME LIGNE
    while($i < 10){
    if ($i==0){
    echo'<TR>';echo'<TH>';
    echo 'BTP PREVOYANCE';
    echo '</TH>';}
    else if ($i ==1){
    echo '<TD>'; echo 'S2 P2'; echo '</TD>';
    }
    else if ($i!=0 && $i!=1 && $i!=6 && $i!=7 && $i!=8){
    while ($data8 = mysql_fetch_assoc($req8)){
    echo '<TD>'; echo $data8['VSO_valeur']; echo '</TD>';
    }}
    else if ($i==6)
    {
    echo '<TD>'; echo '721.80€'; echo '</TD>';
    }
    else if ($i==7)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    else if ($i==8)
    {
    echo '<TD>'; echo ' '; echo '</TD>';
    }
    $i++;
    }
    echo'</TR>';
     
    $i=0;
    Merci d'avance pour votre aide

  2. #2
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2009
    Messages
    736
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2009
    Messages : 736
    Points : 1 101
    Points
    1 101
    Par défaut
    Si tu peux nous expliqué d’où vient les valeur, le schéma de tes tables db. pour te suggéré une meilleur solution si c'est possible.
    A la recherche d'un film : http://chercher-un-film.com

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2013
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 120
    Points : 53
    Points
    53
    Par défaut
    http://hpics.li/a0bd72c

    Je veux, dans mon tableau, que dans la colonne de gauche, j'affiche tous les nom de mutuelle présents.

    Dans la ligne en haut, les nom des différents services.

    Et dans l'intérieur du tableau, les valeurs des services.

  4. #4
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Septembre 2009
    Messages : 875
    Points : 1 313
    Points
    1 313
    Par défaut
    Wow comme c'est moche ce code. ça sert a rien de faire une boucle si tu passes tous les cas dans un if... autant incrémenter a la main...

    Bon allez, trêve de remarque déplaisante, prenons ça en main. Le plus simple d'un point de vue maintenance est de séparée ton traitement de ton affichage.

    Dans ce cas précis, on va implémenter un tableau a deux dimensions.Il faut initialiser chacune de tes cases dans ton tableau en pensant ligne/colonne

    Pour la compréhension, et seulement pour cette raison, on va juste affecter les résultats en durs pour l'instant, ce code est bien sur à travailler

    Commençons par initialiser tes en têtes
    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
     
    $tableau=array(); //$tableau[$ligne][$colonne]
     
    //entete avec tes infos en dures 
    $tableau[0]=array(0=>'APREVA');
    $tableau[1]=array(0=>'LIBRE CHOIX');
    $tableau[2]=array(0=>'JUST EN FAMILLE');
    //etc... 
     
    //Contrats:  
    $tableau[0][1]='ACS';
    $tableau[1][1]='Emeraude';
    $tableau[2][1]='ModuloActif';
     
    //Bref, comme ca pour chaque colonne jusqu’à l'affichage
     
    //  -------------------- AFFICHAGE   -------------------------
    echo '<table>';
    //<-----ICI met ton code des entête horizontaux 
     
    foreach($tableau as $numero_ligne => $ligne){//pour chaque ligne du tableau
        echo '<tr>'; //ca c'est le html du saut de ligne
        foreach($ligne as $numero_colonne => $colonne){//pour chaque colonne
            if($numero_colonne == 0){ //si première colonne
                echo '<th>'.$colonne.'</th>'; //entête verticale
            }else{
                echo '<td>'.$colonne.'</td>'; 
            }
        }
        echo '</tr>';
    }
    echo '</table>'
    Tu remarqueras que présenté de cette manière, on arrive déjà beaucoup mieux a comprendre par quel algorithme on va remplir les données pour l'instant en dur

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2013
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 120
    Points : 53
    Points
    53
    Par défaut
    Oui le code était en effet très moche, les tableaux et moi sa fait 2

    Je vais tester ce que tu m'as donné, merci beaucoup

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2013
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 120
    Points : 53
    Points
    53
    Par défaut
    J'ai un peu de mal pour la compréhension de cette partie :

    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
    //  -------------------- AFFICHAGE   -------------------------
    echo '<table>';
    //<-----ICI met ton code des entête horizontaux 
     
    foreach($tableau as $numero_ligne => $ligne){//pour chaque ligne du tableau
        echo '<tr>'; //ca c'est le html du saut de ligne
        foreach($ligne as $numero_colonne => $colonne){//pour chaque colonne
            if($numero_colonne == 0){
                echo '<th>'.$colonne.'</th>';
            }else{
                echo '<td>'.$colonne.'</td>'; 
            }
        }
        echo '</tr>';
    }
    echo '</table>' ;

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2013
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2013
    Messages : 120
    Points : 53
    Points
    53
    Par défaut
    C'est bon problème solved.

    Merci encore !

  8. #8
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Septembre 2009
    Messages : 875
    Points : 1 313
    Points
    1 313
    Par défaut
    si tu veux poster ton code pour que te donne des pistes d'amélioration n'hésite pas

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

Discussions similaires

  1. Problème avec requête SQL avec variables
    Par harry25 dans le forum ASP
    Réponses: 1
    Dernier message: 03/01/2007, 03h41
  2. VBA avec requête SQL
    Par seba_stien dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 17/10/2006, 15h39
  3. [JDBC]probleme avec requête sql
    Par lkryss dans le forum JDBC
    Réponses: 16
    Dernier message: 10/06/2006, 01h44
  4. [MySQL] Remplir un tableau par requêtes sql
    Par Melekitto dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 11/02/2006, 17h30
  5. [MySQL] Problème de listes déroulantes liées avec requêtes sql
    Par richton95 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 21/12/2005, 16h04

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