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 :

boucle foreach, mysql php


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 11
    Par défaut boucle foreach, mysql php
    Bonjour à tous, je suis débutant en php et nouveau sur ce site, je suis en train de travailler sur une application et je génère des données dans un tableau dans un intervalle de date le soucis c'est que mes données ne s'affiche pas en fonction de la date mais dans la 1ère colonne et j'aimerai avec un foreach régler tout celà avant de poster mon code je précise que tab_dates et tab_donnees sont des array qui se trouve sur autre page servant d'objet.
    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
    echo "<table width='100%'>";
    /*****************************************************************************************************************/
    /********************************EN-TETE DE COLONNE : DATE********************************************************/
    foreach($tab_dates as $an){
        if($an=$anneedatedebut){
             foreach($tab_dates as $mois){
                if($mois=$moisdatedebut){
    $stop=0;
        if(isset($tab_dates))
            echo"<tr>";
            echo"<th>Mois</th>";
            while($anneedatedebut<=$anneedatefin && $stop==0){
                        if($moisdatedebut>12){
                            $moisdatedebut=1;
                            $anneedatedebut++;
                        }          
                echo "<th>".$moisdatedebut."/".$anneedatedebut."</th>";
                  if($moisdatedebut==$moisdatefin && $anneedatedebut==$anneedatefin) $stop++;
                  $moisdatedebut++; 
     
                  }
            echo "</tr>";   
    /****************************************************************************************************************/        
     
    /********************************************REQUETE*************************************************************/
    $j=0;
            $reqAffich1 = "SELECT count(".$tab_donnees[$j][5].") as nombredefnc, month(".$tab_donnees[$j][4].") ,year(".$tab_donnees[$j][4].") from ".$tab_donnees[$j][2]." where ".$tab_donnees[$j][3]."=$idfou  group by year(".$tab_donnees[$j][4]."),month(".$tab_donnees[$j][4].")"; 
    //        	echo $reqAffich1;
    		$result1=mysqli_query($cnx,$reqAffich1) or die ("Erreur de la requête 1");
    $j=1;                
    	$reqAffich2="SELECT sum(".$tab_donnees[$j][5].") as cout, month(".$tab_donnees[$j][4].") ,year(".$tab_donnees[$j][4].") from ".$tab_donnees[$j][2]." where ".$tab_donnees[$j][3]."=$idfou group by year(".$tab_donnees[$j][4]."),month(".$tab_donnees[$j][4].")";	
    //               echo $reqAffich2;
                    $result2=  mysqli_query($cnx, $reqAffich2) or die ("Erreur de la requête 2"); 
    $j=2;                
    	$reqAffich3="SELECT sum(".$tab_donnees[$j][5].") as heure, month(".$tab_donnees[$j][4].") ,year(".$tab_donnees[$j][4].") from ".$tab_donnees[$j][2]." where ".$tab_donnees[$j][3]."=$idfou group by year(".$tab_donnees[$j][4]."),month(".$tab_donnees[$j][4].")";	
    //              echo $reqAffich3;
                    $result3=  mysqli_query($cnx, $reqAffich3) or die ("Erreur de la requête 3");
     
    /****************************************************************************************************************/                
    $j=0;
    /*****************************EN TETE DE LIGNE ET DONNEES********************************************************/
     
                    while(isset($tab_donnees[$j])){
                           echo "<tr>";
                            echo "<th>".$tab_donnees[$j][1]."</th>";
     
                            while($row1 = mysqli_fetch_array($result1)){
                                    echo "<td><center>".$row1['nombredefnc']."</center></td>";
                            }
                            $j++;
                            echo "</tr><tr><th>".$tab_donnees[$j][1]."</th>";
                            while($row2=  mysqli_fetch_array($result2)){
                                    echo "<td><center>".$row2['cout']."</center></td>";
                            }
                            $j++;
                            echo "</tr><tr><th>".$tab_donnees[$j][1]."</th>";
                            while($row3=  mysqli_fetch_array($result3)){
                                    echo "<td><center>".$row3['heure']."</center></td>";
                            }
                            $j++;
                    }
                }
            }
       }
    }
     
    echo "</tr>"; 
        echo "</table>";

  2. #2
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Salut,

    Citation Envoyé par matt62400 Voir le message
    je génère des données dans un tableau dans un intervalle de date le soucis c'est que mes données ne s'affiche pas en fonction de la date mais dans la 1ère colonne
    ça veut dire quoi cette explication ?

    Ne pourrais-tu pas poster un tableau d'exemple fini histoire de voir ce que tu souhaites obtenir, merci :-)

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 11
    Par défaut
    ---------------------------------------------
    Date |09/2015|10/2015|11/2015|
    ----------------------------------------------
    Req1|les valeurs au bon endroit|
    ----------------------------------------------
    Req2| idem
    ----------------------------------------------
    Req3| Idem

  4. #4
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Salut,

    bon je n'ai pas trop le temps mais voici comment générer proprement tes en-têtes en évitant une usine à gaz (tu dois adapter à tes données):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $start = new \DateTime('2015-09-01');
    $end   = new \DateTime('2015-12-31');
     
    // en-tête
    $th = '<th>Mois</th>';
    while ($start < $end)
    {
        $th .= "<th>{$start->format('m/Y')}</th>";
        $start->modify('+1 month');
    }

  5. #5
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 11
    Par défaut
    Sauf que mes dates je ne les écrits pas en dur mais je les récupères sous forme de formulaires là c'était un simple exemple mon en-tête est généré selon un intervalle de date de ce fait, et j'aimerai que les infos de ma BDD soit généré en fonction de celle-ci

  6. #6
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Ben je ne vois pas trop où est le problème...
    Tu n'as qu'à utiliser \DateTime::createfromformat() si nécessaire et tu arriveras au même résultat

  7. #7
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 11
    Par défaut
    Le soucis est que dans ma BDD je n'ai pas de valeur pour chaque date

  8. #8
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Une piste à creuser (1er jeu de 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
    $sql = <<<sql
    SELECT
        COUNT(`id`)                          AS `nb_fnc`,
        DATE_FORMAT(`colonne_date`, '%Y-%m') AS `date_evt`
    FROM
        ta_table
    WHERE
        `colonne` = {$idfou}
    GROUP BY
        `date_evt` ASC
    sql;
     
    $data     = dbData($sql);
    $ord_data = [];
    // on réordonne les données par année-mois
    foreach ($data as $v)
    {
        $ord_data[$v['date_evt']] = $v['nb_fnc']; 
    }
    $html_a   = '<tr>';
    foreach ($range as $k => $ym)
    {
        if ($k === 0)
        {
            $html_a .= '<td>Requête 1</td>';
        }
        elseif (isset($ord_data[$ym]))
        {
            $html_a .= "<td><center>{$ord_data[$ym]}</center></td>";       
        }
        else
        {
            $html_a .= '<td>&nbspc;</td>';        
        }
    }

Discussions similaires

  1. Réponses: 2
    Dernier message: 12/08/2012, 18h43
  2. Insérer puces (UL-LI) dans boucle foreach PHP
    Par RENAUDER dans le forum Langage
    Réponses: 1
    Dernier message: 21/01/2009, 11h18
  3. [mysql][php]aucune base selectionnée
    Par Destampy dans le forum Requêtes
    Réponses: 3
    Dernier message: 01/06/2005, 10h21
  4. Types de variables entre mysql/php et flash
    Par ramses83 dans le forum Flash
    Réponses: 2
    Dernier message: 06/10/2003, 18h35
  5. Réponses: 14
    Dernier message: 17/03/2003, 18h31

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