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 :

[Symfony 2] Custom select dropdown à partir d'une entity


Sujet :

Symfony PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2
    Par défaut [Symfony 2] Custom select dropdown à partir d'une entity
    Bonjour à tous,

    J'ai un souci assez ennuyeux... Je dois créer à partir d'une query SQL ma dropdown list pour un formulaire.

    Voici ma query (qui fonctionne très bien quand je la joue sur Navicat) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT DISTINCT o.name FROM organisation o
    	INNER JOIN relorganisationrecherche rel ON rel.organisation_id = o.id
    UNION
    SELECT DISTINCT o.name FROM organisation o
    WHERE o.id IN (SELECT DISTINCT o.parent_id FROM organisation o
    	INNER JOIN relorganisationrecherche rel ON rel.organisation_id = o.id)
    ORDER BY name
    Le gros problème est que Doctrine 2.0 ne comprend pas la syntaxe UNION, donc DQL et QueryBuilder impossible à utiliser.

    J'ai donc pensé, dans mon formulaire, à utiliser l'option "property" qui permet d'utiliser une méthode de la classe précisée pour construire la dropdown... La aussi ça cloche, je ne peux pas accéder à mon Repository dans ma classe Entity...

    Je ne peux pas utiliser le type choice pour le formulaire, car mon champs doit être mappé à une classe spécifique pour la suite de la gestion, donc je ne peux pas build un array à partir d'une static méthode ou quoi que ce soit dans ce style là.

    Il me faudrait en fait un moyen de getEntityManager() lorsque je suis dans mon entity, ou alors de pouvoir utiliser dans l'option query_builder de mon champs, une syntaxe SQL...

    Voici le code du champs de mon formulaire :
    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
    ->add('organisations', 'entity', array(
                  'class' => 'ResearchBundle:Organisation',
                  //'property' => 'getOrgaList',
                  //'choices' => $this->getOrgaList(),
                  'multiple' => false,
                  'required' => false,
                  'empty_value' => 'Liste des organisations',
                  'label' => 'Organisation',
    //              'query_builder' => function (\Cofraref\Cofradmin\ResearchBundle\Entity\OrganisationRepository $er) {
    //                 return $er->createQueryBuilder('s')
    //                        ->select('organisation')
    //                        ->from('\Cofraref\Cofradmin\ResearchBundle\Entity\Organisation', 'organisation')
    //                        ->innerJoin('organisation.recherches', 'rel')
    //                        ->add('orderBy', 'organisation.name ASC');
    //              }
              ))

    Merci d'avance pour votre aide, j'avoue que je sèche un peu là...

  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
    J'ai peut être mal compris ta requête mais pour moi la seconde requête après le union ne sert à rien...

  3. #3
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Octobre 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2011
    Messages : 2
    Par défaut
    Dans mon modèle, des recherches sont liées à des organisations (many to many donc table de relation)

    La petite astuce est que sur la table organisation, s'opère une filiation grâce au champ parent_id .

    Mon job est de séléctionner les organisations liées à des recherches (première partie de la requête avec INNER JOIN), et ensuite je dois sélectionner les organisations parentes (qui ne sont jamais réellement liées aux recherches) qui ont des organisations enfants liées à des recherches.

    Je ne sais pas si je me suis bien fait comprendre, si pas, je peux réexpliquer avec d'autres mots

Discussions similaires

  1. selection random à partir d'une liste d'objet
    Par emna hakem dans le forum C#
    Réponses: 4
    Dernier message: 29/04/2011, 20h09
  2. Select dynamique à partir d'une liste
    Par CPI_en_mousse dans le forum Struts 1
    Réponses: 4
    Dernier message: 03/05/2007, 10h01
  3. Remplir deux listes select à partir d'une autre
    Par Raduris dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 23/11/2005, 15h29
  4. [C#] custom control à partir d'une image / alpha blending
    Par Cyberwan dans le forum Windows Forms
    Réponses: 5
    Dernier message: 13/11/2005, 21h59
  5. Réponses: 3
    Dernier message: 03/08/2005, 11h21

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