Précédent   Forum des professionnels en informatique > PHP > Outils > Zend > Zend Framework
Zend Framework Forum d'entraide sur la programmation PHP avec Zend Framework. Avant de poster -> FAQ ZF, Cours ZF
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 18/02/2011, 16h44   #1
Modérateur
 
Avatar de CinePhil
 
Homme Philippe Leménager
Ingénieur d'études en informatique
Inscription : août 2006
Messages : 10 990
Détails du profil
Informations personnelles :
Nom : Homme Philippe Leménager
Âge : 48
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 : 10 990
Points : 18 241
Points : 18 241
Envoyer un message via MSN à CinePhil
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 :
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 :
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 :
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 de Formation Agronomique.
Mon blog sur la conception des BDD, le langage SQL, le PHP avec Zend Framework...
« 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 Mandriva Linux ou Mageïa ! Soutenons l'industrie logicielle française !
Linuxiens, comptez-vous !
CinePhil est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/02/2011, 16h14   #2
Modérateur
 
Avatar de CinePhil
 
Homme Philippe Leménager
Ingénieur d'études en informatique
Inscription : août 2006
Messages : 10 990
Détails du profil
Informations personnelles :
Nom : Homme Philippe Leménager
Âge : 48
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 : 10 990
Points : 18 241
Points : 18 241
Envoyer un message via MSN à CinePhil
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 :
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 de Formation Agronomique.
Mon blog sur la conception des BDD, le langage SQL, le PHP avec Zend Framework...
« 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 Mandriva Linux ou Mageïa ! Soutenons l'industrie logicielle française !
Linuxiens, comptez-vous !
CinePhil est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 09h15.


 
 
 
 
Partenaires

Hébergement Web