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 :

custom method findBy()


Sujet :

Doctrine2 PHP

  1. #1
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2012
    Messages : 24
    Par défaut custom method findBy()
    Bonjour,

    Je voudrais créer ma propre methode findBy().
    J'ai deux entités : films et genres. Le but de refaire une methode findBy est d'inclure donc, la jointure avec l'entité "genre" pour récupérer tous mes films et les genres associés, et de conserver les paramètres de la méthode de base à savoir : $criteres, $orderBy, $limite et $offset.
    Je me sers de ses paramètres pour faire une pagination.


    Pour l'instant j'ai une methode myFindAll(), avec la jointure voulue :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <?php
    public function myFindAll()
    {
        $films = $this->createQueryBuilder('f')
            // leftJoin because I need all the genre
            ->leftJoin('f.genres', 'g')
            ->addSelect('g.label')
            ->groupBy('f.id')
            ->getQuery()
            ->getArrayResult();
        // $genres contains all the genres and the associated movies
        return ($films);
    }
    Merci d'avance,
    Adrien

  2. #2
    Membre expérimenté

    Inscrit en
    Juin 2008
    Messages
    307
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 307
    Par défaut
    Et quelle est ta question ?
    Ça me parait pas mal la non ?

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2012
    Messages : 24
    Par défaut
    Pour l'instant ma fonction myFindAll est bonne, il n'y a pas de soucis. Je l'ai posté car on va surement se servir de la jointure pour faire la nouvelle methode findBy().

    la methode myFindAll ne prend pas de paramètres.
    L'intéret de la fonction de base findBy() c'est qu'elle permet de mettre en place de filtres. Voici les paramètres en question :
    findBy(array $criteres, array $orderBy = null, $limite = null, $offset = null)

    Je souhaite refaire cette méthode en incluant une jointure afin que l'entité Film soit liée avec l'entité Genre.

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

    Informations forums :
    Inscription : Juin 2011
    Messages : 725
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
            ->leftJoin('f.genres', 'g')
            ->addSelect('g.label')
    tu ne charge que le label de genre, attention, il y a des précautions à prendre lorsque l'on ne charge que partiellement les objets:
    http://docs.doctrine-project.org/pro...l-objects.html

    Si la finalité est de redéfinir la méthode findBy pour un repository donné, ça risque d'avoir des effets de bords


    D'autre part tu peux aussi utiliser les fetch mode pour charger automatiquement certaines relations.


    Sinon avoir une méthode générique pour faire des filtres et autres ça donnerait quelque chose comme cela
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    public function filterQB(QueryBuilder $qb,$alias,$filters=array(),$orderBy=array(),$limit,){
      foreach($filters as $field=>$value){
          $qb->andWhere($alias.'.'.$field.'=:'.$field)->setParameter($field,$value);
      }
     foreach($orderBy as $field=>$order){
           $qb->addOrderBy($alias.'.'.$field,$order);
    }
    }

  5. #5
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2012
    Messages : 24
    Par défaut
    J'avoue que je ne vois pas comment appliquer ta solution ^^'

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

    Informations forums :
    Inscription : Juin 2011
    Messages : 725
    Par défaut
    une méthode comme celle-ci
    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
     
    public function findJoinGenre($criterias=array(),$orderBy=array())
    {
        $qb = $this->createQueryBuilder('f')
            // leftJoin because I need all the genre
            ->leftJoin('f.genres', 'g')
            ->addSelect('g.label')
            ->groupBy('f.id');
        foreach($criterias as $field=>$value){
          $qb->andWhere('f.'.$field.'=:'.$field)->setParameter($field,$value);
        }
       foreach($orderBy as $field=>$order){
           $qb->addOrderBy('f.'.$field,$order);
       }
     
       return $qb->getQuery()
            ->getArrayResult();
    }

  7. #7
    Membre averti
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2012
    Messages : 24
    Par défaut
    Bonjour,

    Merci pour ton exemple, est ce que l'on peut inclure aussi les paramètres ($offset et $limit) pour me permettre de faire une pagination ?

Discussions similaires

  1. Réponses: 0
    Dernier message: 15/05/2014, 20h53
  2. [Propel] Custom methods ne repondent pas
    Par wilsakovi dans le forum ORM
    Réponses: 8
    Dernier message: 17/05/2011, 21h11
  3. erreur avec la methode findBy
    Par dalidali86 dans le forum JSF
    Réponses: 3
    Dernier message: 27/09/2009, 22h30
  4. Passage de variable par methode post ?
    Par oazar dans le forum Flash
    Réponses: 33
    Dernier message: 16/10/2003, 17h03
  5. Methode de drcherche a l,interieur de basse de donner texte
    Par philippe V dans le forum Autres SGBD
    Réponses: 4
    Dernier message: 03/12/2002, 10h20

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