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

ORM PHP Discussion :

Erreur dans un formulaire de recherche par critères [4.x]


Sujet :

ORM PHP

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut Erreur dans un formulaire de recherche par critères
    Bonjour,

    J'ai un formulaire de recherche basé sur des critères complétés par l'utilisateur. Dans ces critères, il y en a qui correspondent à des équipements qui peuvent être de deux sortes : ceux liés à la cellule et ceux liés au porteur.

    Lors du chargement du formulaire, voici l'erreur que j'obtiens :

    Entity of type "App\Entity\Equipment" passed to the choice field must be managed. Maybe you forget to persist it in the entity manager?
    Pour effectuer la recherche, j'ai créé une entité "AdvertSearch.php" qui est hydratée par le formulaire de recherche.

    Voici le code correspondant aux champs liés à l'équipement dans 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
    17
    18
    19
    20
    21
    22
    23
    24
    25
     
    ...
            $builder 
    ...
                ->add('cellEquipments', EntityType::class, ['required' => false,
                                                            'label' => false,
                                                            'class' => 'App\Entity\Equipment',
                                                            'choice_label' => 'equipment',
                                                            'multiple' => true, 
                                                            'query_builder' => function(EquipmentRepository $er) use ($belongingCell) {
                                                                                    return $er->queryFindByBelonging($belongingCell);
                                                                               }
                                                           ]
                     )
                ->add('carrierEquipments', EntityType::class, ['required' => false,
                                                               'label' => false,
                                                               'class' => 'App\Entity\Equipment',
                                                               'choice_label' => 'equipment',
                                                               'multiple' => true,
                                                               'query_builder' => function(EquipmentRepository $er) use ($belongingCarrier) {
                                                                                       return $er->queryFindByBelonging($belongingCarrier);
                                                                                  }
                                                              ]
                     )
    ...
    Dans mon entité 'AdvertSearch.php", voici les propriétés , setters et getters liés :

    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
     
    ...
        /**
         * @var ArrayCollection
         */
        private $cellEquipments;
     
        /**
         * @var ArrayCollection
         */
        private $carrierEquipments;
    ...
        public function __construct()
        {
     
            $this->cellEquipments = new ArrayCollection();
            $this->carrierEquipments = new ArrayCollection();
     
        }
    ...
        /**
         * @param ArrayCollection $cellEquipments
         */
        public function setCellEquipments(ArrayCollection $cellEquipments): void
        {
     
            $this->cellEquipments = $cellEquipments;
     
        }
     
        /**
         * @return ArrayCollection 
         */
        public function getCellEquipments(): ArrayCollection
        {
     
            return $this->cellEquipments;
     
        }
     
        /**
         * @param ArrayCollection $carrierEquipments
         */
        public function setCarrierEquipments(ArrayCollection $carrierEquipments): void
        {
     
            $this->carrierEquipments = $carrierEquipments;
     
        }
     
        /**
         * @return ArrayCollection 
         */
        public function getCarrierEquipments(): ArrayCollection
        {
     
            return $this->carrierEquipments;
     
        }
    ...
    Voici le code correspondant à la tenue en compte de ces critères dans ma fonction de recherche dans le repository :

    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
     
    ...
            $cellEquipments = $search->getCellEquipments();
     
            if ($cellEquipments->count() > 0)
            {
     
                $k = 0;
     
                foreach ($cellEquipments as $k => $cellEquipment) 
                {
     
                    $k++;
     
                    $query = $query->andWhere(":cellEquipment$k MEMBER OF v.cellEquipments")
                                   ->setParameter("cellEquipment$k", $cellEquipment)
                    ;
     
                }
     
            }
     
            $carrierEquipments = $search->getCarrierEquipments();
     
            if ($carrierEquipments->count() > 0)
            {
     
                $l = 0;
     
                foreach ($carrierEquipments as $l => $carrierEquipment) 
                {
     
                    $l++;
     
                    $query = $query->andWhere(":carrierEquipment$l MEMBER OF v.carrierEquipments")
                                   ->setParameter("carrierEquipment$l", $carrierEquipment)
                    ;
     
                }
     
            }
    ...
    Quelqu'un aurait une idée sur la manière de résoudre ce problème?

    Merci d'avance pour votre aide.

  2. #2
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    Bon, en continuant à effectuer mes recherches quant à l'origine de l'erreur, j'ai remarqué que celle-ci ne survient que lorsque j'effectue pour la seconde fois une recherche avec un critèred'équipement.

    Un peiti exemple de flux :

    1. J'effectue une recherche sans critère lié à l'équipement : tout est ok
    2. Je relance une recherche avec un critère lié à l'équipement : tout est ok
    3. Je relance une recherche avec un critère lié à l'équipement : erreur ci-dessus décrite

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    Problème résolu en supprimant la variable de session après l'avoir récupérée dans le controller.

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

Discussions similaires

  1. Réponses: 15
    Dernier message: 04/03/2013, 02h20
  2. Réponses: 3
    Dernier message: 31/05/2011, 18h25
  3. recherche multi-critères dans un formulaire de recherche
    Par sam1975 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 02/08/2009, 18h12
  4. Réponses: 2
    Dernier message: 23/05/2007, 07h31
  5. Réponses: 6
    Dernier message: 28/06/2006, 15h01

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