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 :

Jointure sur 3 entités A->B->C


Sujet :

Doctrine2 PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    72
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 72
    Points : 59
    Points
    59
    Par défaut Jointure sur 3 entités A->B->C
    Bonjour,

    J'ai 3 entités:
    1. Article
    2. ArticleCompetency => ManyToOne vers Article et ManyToOne vers Competency
    3. Competency

    Dans ArticleRepository, je crée une méthode pour renvoyer un article avec ces compétences (et son attribut "niveau" qui se trouve dans ArticleCompetency).

    Ca donne cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    class ArticleRepository extends EntityRepository
    {
      public function getWithCompetencies($id)
      {
        $qb = $this->createQueryBuilder('a');
        $qb ->leftJoin('a.competencies', 'comp')
            ->addSelect('comp')
            ->where('a.id = :id')
            ->setParameter('id', $id);
        return $qb->getQuery()
                  ->getResult();
      }
    }
    a.competencies étant la relation inverse de ArticleCompetency vers Article

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
        /**
         * @ORM\OneToMany(targetEntity="acama\REPP\BlogBundle\Entity\ArticleCompetency", mappedBy="article")
         */
        private $competencies;
    Ca marche bien et je récupère dans getResult un tableau avec un objet ou j'ai bien mon article, l'Id de la compétence qui se trouve dans ArticleCompetency et le niveau qui se trouve dans la même entité.

    Le problème est que je ne vois pas comment aller chercher la désignation de la compétence qui se trouve dans Competency.
    Comment faire la jointure entre ArticleCompetency et Competency, dans ma méthode getWithCompetencies ?

    Merci d'avance pour votre aide.

  2. #2
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    725
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juin 2011
    Messages : 725
    Points : 1 050
    Points
    1 050
    Par défaut
    Bonjour,

    Je vois pas trop le problème si ce n'est au niveau du nommage (si tu as une collection d'objet ArticleCompetency dans Article, mieux vaut l'appeler articleCompetencies +tôt que competencies)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    public function getWithCompetencies($id)
      {
        $qb = $this->createQueryBuilder('a');
        $qb ->leftJoin('a.competencies', 'comp')
              ->leftJoin('comp.competency','comp2')
            ->addSelect('comp,comp2')
            ->where('a.id = :id')
            ->setParameter('id', $id);
        return $qb->getQuery()
                  ->getResult();
    //NB plutôt que de récupérer un tableau avec 1 entité, autant récupérer directement l'entité avec
         return $qb->getQuery()->getSingleResult();
      }

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    72
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 72
    Points : 59
    Points
    59
    Par défaut
    arnooo999, c'est exactement ce que je cherchais. Dans le mille dès le premier tir!
    Bravo et merci!
    Je ne pensais pas qu'on pouvait utiliser l'alias défini dans la jointure des lignes précédentes.

    Merci également pour la suggestion de récupération. J'ai finalement utilisé getOneOrNullResult car je souhaite gérer l'exception si pas de résultat renvoyé.

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 14/04/2013, 04h04
  2. Jointure sur un champ et non une entité
    Par shadypierre dans le forum Doctrine2
    Réponses: 3
    Dernier message: 24/09/2012, 14h00
  3. jointure sur une même table
    Par guillaumeVb6 dans le forum Langage SQL
    Réponses: 7
    Dernier message: 06/09/2004, 15h08
  4. jointure sur TROIS tables
    Par caribou_belle dans le forum Langage SQL
    Réponses: 8
    Dernier message: 01/03/2004, 11h20
  5. Jointure sur 2 tables de bases différentes
    Par Celina dans le forum Langage SQL
    Réponses: 10
    Dernier message: 10/11/2003, 11h56

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