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

Zend Framework PHP Discussion :

Plusieurs lignes de table SQL dans une ligne de tableau de données [ZF 1.11]


Sujet :

Zend Framework PHP

  1. #1
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut Plusieurs lignes de table SQL dans une ligne de tableau de données
    Bonjour.
    C'est peut-être le syndrome du vendredi mais je ne trouve pas la bonne manière de présenter mes données.

    Soit une fonction dans le modèle qui retourne le résultat d'une requête.
    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
        public function listeStages()
        {
            $sql = "
                SELECT sn.ssn_id, sn.ssn_code, sn.ssn_libelle, 
                    sn.ssn_date_debut, sn.ssn_date_fin, sn.ssn_capacite, 
                    st.stg_id_etablissement, st.stg_id_conseiller_pedago, 
                    e.etb_nom, 
                    c.cmn_id, c.cmn_nom, 
                    p.prs_nom, p.prs_prenom,
                    d.dsc_id, d.dsc_nom 
                FROM th_stage_stg st 
                INNER JOIN te_session_ssn sn ON sn.ssn_id = st.stg_id_session 
                INNER JOIN te_personne_prs p ON p.prs_id = st.stg_id_conseiller_pedago 
                INNER JOIN te_etablissement_etb e ON e.etb_id = st.stg_id_etablissement 
                    INNER JOIN tr_commune_cmn c ON c.cmn_id = e.etb_id_commune 
                INNER JOIN tj_stg_concerner_dsc_scd sc ON sc.scd_id_stage = st.stg_id_session
                    INNER JOIN te_discipline_dsc d ON d.dsc_id = sc.scd_id_discipline
            ";
            return $this->_db->fetchAll($sql);
        }
    Comme un stage peut couvrir plusieurs disciplines, je peux avoir plusieurs lignes de résultat pour un stage.

    Maintenant, je veux présenter les données de ce résultat de requête dans le tableau de données d'une vue :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <table>
        <tr>
            <th>Code</th>
            <th>Libellé</th>
            <th>Dates</th>
            <th>Établissement</th>
            <th>Conseiller prédagogique</th>
            <th>Discipline(s) couverte(s)</th>
            <th>&nbsp;</th>
        </tr>
    <?php foreach($this->stages as $stage) : ?>
    Et là je coince sur la manière de faire en sorte qu'un stage ne prenne qu'une ligne de mon tableau en rassemblant toutes les disciplines du stage séparées par des virgules, de la forme "Physique, Chimie".
    J'ai commencé à faire ce genre de truc :
    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
        <?php 
        if($id_prec != $stage['ssn_id'])
        {
            // Nouveau stage à traiter
            $disciplines = $this->escape($stage['dsc_nom']);
            $newline = 1;
        }
        else
        {
            // Stage multi-disciplines
            $disciplines .= ', '.$this->escape($stage['dsc_nom']);
            $newline = 0;
        }
        ?>
        <?php if($newline == 1) : ?>
            <tr>
                <td><?php echo $this->escape($stage['ssn_code']); ?></td>
                <td><?php echo $this->escape($stage['ssn_libelle']); ?></td>
                <td>Du : 
                    <?php echo $this->escape($stage['ssn_date_debut']); ?><br />
                    Au : 
                    <?php echo $this->escape($stage['ssn_date_fin']); ?>
                </td>
                <td>
                    <?php echo $this->escape($stage['etb_nom']); ?> (
                    <?php echo $this->escape($stage['cmn_nom']); ?>)
                </td>
                <td>
                    <?php echo $this->escape($stage['prs_prenom']); ?> 
                    <?php echo $this->escape($stage['prs_nom']); ?>
                </td>
                <td>
        <?php endif; ?>
                    <?php echo $this->escape($disciplines); ?>
    Et là il faut que je passe à l'instance suivante du foreach pour éventuellement compléter la cellule accueillant les disciplines. Mais si le stage n'a qu'une discipline, je n'ai pas encore changé de ligne de tableau et les données vont se mélanger.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Le lundi les neurones sont plus frais que le vendredi !
    J'ai trouvé une solution en recréant un tableau de données dans le contrôleur à partir du tableau de résultats de la requête :
    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
            // Récupération de la liste des stages
            $stages = new Application_Model_DbTable_Stage();
            $listestages = $stages->listeStages();
            $idprec = 0;
            $lstages = array();
     
            // Certains stages peuvent avoir plusieurs disciplines et donc plusieurs lignes dans $listestages
            // Constitution d'un tableau avec une seule ligne par stage
            foreach($listestages as $ligne => $stage)
            {
                if($idprec != (int)$stage['ssn_id'])
                {
                    // Nouveau stage à traiter
                    $lstages[(int)$stage['ssn_id']] = $stage;
                    $disciplines = $stage['dsc_nom'];
                } 
                else
                {
                    // Stage multi-disciplines
                    $disciplines .= ', '.$stage['dsc_nom'];
                    $lstages[(int)$stage['ssn_id']]['dsc_nom'] = $disciplines;
                } // Fin if($idprec == $stage['ssn_id'])
                $idprec = $stage['ssn_id'];
            } // Fin foreach($listestages as $ligne => $stage)
     
            $this->view->stages = $lstages;
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

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

Discussions similaires

  1. [WD16] calcul dans une ligne de table
    Par kirikou84 dans le forum WinDev
    Réponses: 12
    Dernier message: 02/01/2020, 11h43
  2. Réponses: 9
    Dernier message: 05/11/2012, 15h28
  3. Réponses: 2
    Dernier message: 22/11/2011, 14h06
  4. Réponses: 2
    Dernier message: 30/01/2008, 22h40
  5. taille max de nb de caractère dans une ligne de table mysql
    Par zidenne dans le forum Administration
    Réponses: 1
    Dernier message: 01/09/2006, 11h04

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