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

Doctrine2 PHP Discussion :

Séparer les resultats d'une colonne


Sujet :

Doctrine2 PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    BTS IRIS
    Inscrit en
    Février 2012
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : BTS IRIS

    Informations forums :
    Inscription : Février 2012
    Messages : 19
    Par défaut Séparer les resultats d'une colonne
    Bonjour,

    J'ai un problème depuis hier, je m'en remets donc à vous car je ne vois vraiment pas.

    Problème:

    Je souhaite séparer chaque enregistrement (lignes) du résultats de ma requête.

    Voila ou j'en suis:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $queryId=$this->getDoctrine()->getEntityManager()->createQuery("SELECT b.livreIdlivre FROM LGBBourseLivresBundle:EleveHasLivre b WHERE b.eleveIdeleve=43");
    		$resultId=$queryId->getResult();
     
            print_r($resultId);
    Mon print_r me donne bien ce que j'ai demandé avec ma requête. Mais (second problème) dès je veux parcourir mon tableau à l'aide de la boucle foreach je me heurte a un mur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    foreach ($resultId as $subarray)
    		{
    		  $test=$subarray['libreIdlivre'];
    		}
    Je tente d'afficher la variable test mais dans cette variable se trouve seulement le dernier enregistre et encore, car quand j'affiche le tableau test case par case, la moitié de ma valeur se trouve à la case d'indice 0 et l'autre moitié à la case d'indice 1.

    Merci de votre aide d'avance

    YoshV

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    pourquoi tu crées une requete ? utilises ton Repository ...

  3. #3
    Membre averti
    Homme Profil pro
    BTS IRIS
    Inscrit en
    Février 2012
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : BTS IRIS

    Informations forums :
    Inscription : Février 2012
    Messages : 19
    Par défaut
    Je viens d'y faire avec repository...

    je cherche a obtenir le résultat après seulement il ne me trouve ,apparemment pas la méthode getContenu(), est-ce bien cette méthode qu'il faut utiliser?

    Ou alors ai-je fais une erreur à quelques parts?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $repository=$this->getDoctrine()
                             ->getEntityManager()
                             ->getRepository('LGBBourseLivresBundle:EleveHasLivre');
     
            $liste_idlivre=$repository->findByeleveIdeleve('43');
     
            foreach($liste_idlivre as $idlivre)
            {
                echo $idlivre->getContenu();
            }

  4. #4
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    montre ton Entity EleveHasLivre,

    pourquoi tu fais ta boucle avec un echo dans ton controller ?

  5. #5
    Membre averti
    Homme Profil pro
    BTS IRIS
    Inscrit en
    Février 2012
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : BTS IRIS

    Informations forums :
    Inscription : Février 2012
    Messages : 19
    Par défaut
    Afin de tester si ce qui se trouve dans ma variable est bien ce que je recherche.

    Voilà mon EleveHasLivre:

    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
    <?php
     
    namespace LGB\BourseLivresBundle\Entity;
     
    use Doctrine\ORM\Mapping as ORM;
     
    /**
     * LGB\BourseLivresBundle\Entity\EleveHasLivre
     *
     * @ORM\Table(name="eleve_has_livre")
     * @ORM\Entity(repositoryClass="LGB\BourseLivresBundle\Entity\EleveHasLivreRepository")
     */
    class EleveHasLivre
    {
        /**
         * @var integer $eleveIdeleve
         *
         * @ORM\Column(name="eleve_ideleve", type="integer", nullable=false)
         * @ORM\Id
         * @ORM\GeneratedValue(strategy="NONE")
         */
        private $eleveIdeleve;
     
        /**
         * @var integer $livreIdlivre
         *
         * @ORM\Column(name="livre_idlivre", type="integer", nullable=false)
         * @ORM\Id
         * @ORM\GeneratedValue(strategy="NONE")
         */
        private $livreIdlivre;
     
        /**
         * @var Eleve
         *
         * @ORM\ManyToOne(targetEntity="Eleve")
         * @ORM\JoinColumns({
         *   @ORM\JoinColumn(name="eleve_ideleve", referencedColumnName="ideleve")
         * })
         */
        private $eleveeleve;
     
        /**
         * @var Livre
         *
         * @ORM\ManyToOne(targetEntity="Livre")
         * @ORM\JoinColumns({
         *   @ORM\JoinColumn(name="livre_idlivre", referencedColumnName="idlivre")
         * })
         */
        private $livrelivre;
     
        /**
         * @var Statut
         *
         * @ORM\ManyToOne(targetEntity="Statut")
         * @ORM\JoinColumns({
         *   @ORM\JoinColumn(name="statut_idstatut", referencedColumnName="idstatut")
         * })
         */
        private $statutstatut;
     
     
     
        /**
         * Set eleveIdeleve
         *
         * @param integer $eleveIdeleve
         */
        public function setEleveIdeleve($eleveIdeleve)
        {
            $this->eleveIdeleve = $eleveIdeleve;
        }
     
        /**
         * Get eleveIdeleve
         *
         * @return integer 
         */
        public function getEleveIdeleve()
        {
            return $this->eleveIdeleve;
        }
     
        /**
         * Set livreIdlivre
         *
         * @param integer $livreIdlivre
         */
        public function setLivreIdlivre($livreIdlivre)
        {
            $this->livreIdlivre = $livreIdlivre;
        }
     
        /**
         * Get livreIdlivre
         *
         * @return integer 
         */
        public function getLivreIdlivre()
        {
            return $this->livreIdlivre;
        }
     
        /**
         * Set eleveeleve
         *
         * @param LGB\BourseLivresBundle\Entity\Eleve $eleveeleve
         */
        public function setEleveeleve(\LGB\BourseLivresBundle\Entity\Eleve $eleveeleve)
        {
            $this->eleveeleve = $eleveeleve;
        }
     
        /**
         * Get eleveeleve
         *
         * @return LGB\BourseLivresBundle\Entity\Eleve 
         */
        public function getEleveeleve()
        {
            return $this->eleveeleve;
        }
     
        /**
         * Set livrelivre
         *
         * @param LGB\BourseLivresBundle\Entity\Livre $livrelivre
         */
        public function setLivrelivre(\LGB\BourseLivresBundle\Entity\Livre $livrelivre)
        {
            $this->livrelivre = $livrelivre;
        }
     
        /**
         * Get livrelivre
         *
         * @return LGB\BourseLivresBundle\Entity\Livre 
         */
        public function getLivrelivre()
        {
            return $this->livrelivre;
        }
     
        /**
         * Set statutstatut
         *
         * @param LGB\BourseLivresBundle\Entity\Statut $statutstatut
         */
        public function setStatutstatut(\LGB\BourseLivresBundle\Entity\Statut $statutstatut)
        {
            $this->statutstatut = $statutstatut;
        }
     
        /**
         * Get statutstatut
         *
         * @return LGB\BourseLivresBundle\Entity\Statut 
         */
        public function getStatutstatut()
        {
            return $this->statutstatut;
        }
    }

    Car je vais devoir réutiliser ces informations dans mon controller par la suite. Car chacun des ids que ça me retourne me permet d'identifié chacun des livres que j'afficherais dans les views.


    Il est vrai que dans mon Entity je ne vois aucun getContenu(). Je pensais qu'elle était généré automatiquement, je me trompe?

  6. #6
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    c'est que ta table de jointure, Contenu fait parti de l'entité livre ?

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 29/07/2011, 09h07
  2. Séparer les données d'une colonne en 3
    Par ALINE85 dans le forum Excel
    Réponses: 5
    Dernier message: 06/03/2009, 13h47
  3. utiliser les resultat d'une requete comme colonnes de la dexieme
    Par Vega779 dans le forum Développement
    Réponses: 3
    Dernier message: 07/12/2007, 20h45
  4. Réponses: 3
    Dernier message: 07/12/2007, 20h45
  5. afficher les resultats d'une requete mysql sur 3 colonnes
    Par harlock59 dans le forum Requêtes
    Réponses: 7
    Dernier message: 24/12/2005, 14h38

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