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

Symfony PHP Discussion :

Requête sous Doctrine symfony2


Sujet :

Symfony PHP

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Novembre 2011
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2011
    Messages : 27
    Points : 20
    Points
    20
    Par défaut Requête sous Doctrine symfony2
    Bonjour,

    J'ai trois tables: User, Product, Message.

    Nom : Capture d’écran 2014-10-07 à 16.16.39.png
Affichages : 142
Taille : 26,6 Ko

    Je veux récupéré que le dernier message de chaque user.

    La requête que j'ai faite me renvoie toute les messages.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    $qb = $this->getDoctrine()
               ->getRepository('BaseBundle:Message')
               ->createQueryBuilder('a')
               ->leftJoin('a.product', 'b')->addSelect('b')
               ->leftJoin('a.user', 'c')->addSelect('c')
               ->where('b.user = :id')
               ->setParameter('id', $this->get('security.context')->getToken()->getUser())
               ->orderBy('a.id','DESC');
    Est ce qu'une personne peut me dire comment faire le filtre.

    Cordialement.

  2. #2
    Modérateur
    Avatar de kolodz
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    2 211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 211
    Points : 8 316
    Points
    8 316
    Billets dans le blog
    52
    Par défaut
    Il y a plusieurs solutions :

    Solution 1 :
    Crée une colonne dans la table user qui référence le dernière message de l'utilisateur.
    Lors de la création d'un message par un utilisateur, mettre à jour ce lien.

    Solution 2 :
    Ajouter un limite à la requête. Sachant que le retour est ordonné et ne concerne qu'un seul utilisateur. La requête n'a besoin de ne retourner que le premier élément :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $limit = 1;
    $query->setMaxResults($limit);
    Solution 3 :
    Utiliser une sous requête ou une requête native. Pour cela je t'invite à faire tes propres recherche. Mais voici quelques liens utiles :
    http://www.philipphoffmann.de/blog/2...ny-complexity/
    http://doctrine-orm.readthedocs.org/...ative-sql.html

    Cordialement,
    Patrick Kolodziejczyk.
    Si une réponse vous a été utile pensez à
    Si vous avez eu la réponse à votre question, marquez votre discussion
    Pensez aux FAQs et aux tutoriels et cours.

  3. #3
    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
    Que donnerait ceci?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $qb = $this->getDoctrine()
               ->getRepository('BaseBundle:Message')
               ->createQueryBuilder('a')
               ->leftJoin('a.product', 'b')->addSelect('b')
               ->leftJoin('a.user', 'c')->addSelect('c')
               ->where('b.user = :id')
               ->setParameter('id', $this->get('security.context')->getToken()->getUser())
               ->orderBy('a.id','DESC')
               ->groupBy('a')
               ->having('MAX(a.createdAt)')
    ;
    Une autre possibilité serait d'utiliser l'API Criteria http://doctrine-orm.readthedocs.org/...ng-collections (en utilisant orderBy et maxResult)
    Le Criteria s'appliquerait sur la collection "messages" de l'entité User (sans passer directement par l'entity Manager)

  4. #4
    Membre régulier
    Homme Profil pro
    Datascientist
    Inscrit en
    Août 2008
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Datascientist
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2008
    Messages : 248
    Points : 110
    Points
    110
    Par défaut
    Bonjour,
    la solution adéquate est d'ajouter une limite à la requête, c'est très simple, mais si tu peux utiliser findOneBy() le problème c'est qu'elle n'accepte pas orderBy et groupBy.

    Bon courage

    marquer la discussion comme résolu si une des solutions est bonne

Discussions similaires

  1. Difficultés à formuler une requête sous Doctrine
    Par caema dans le forum Doctrine2
    Réponses: 2
    Dernier message: 26/06/2014, 17h12
  2. Réponses: 0
    Dernier message: 04/11/2011, 19h17
  3. formatage des requêtes sous psql
    Par Bouboubou dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 03/02/2004, 11h10
  4. Syntaxe PARAMETERS pour requête sous VBA
    Par GAGNON dans le forum VBA Access
    Réponses: 3
    Dernier message: 28/11/2003, 11h39
  5. Requete requête sous sybase
    Par eddie dans le forum Sybase
    Réponses: 3
    Dernier message: 02/04/2003, 14h51

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