2017-02-17 17 views
0

私のFormTypeに問題があります。私はデータを表示したいのですが、querybuilderに感謝しています。私のメソッドを - > select( 't.nomVern')で呼び​​出すと問題が発生する "警告:spl_object_hash()はパラメータ1がオブジェクトであり、指定された文字列であると想定しています"というエラーメッセージが表示されます。FormType&method repository

なぜか分かりません。

私にformType ObservationType:

<?php 

namespace ObservationBundle\Form; 

use Symfony\Bridge\Doctrine\Form\Type\EntityType; 
use Symfony\Component\Form\AbstractType; 
use Symfony\Component\Form\Extension\Core\Type\DateType; 
use Symfony\Component\Form\Extension\Core\Type\HiddenType; 
use Symfony\Component\Form\Extension\Core\Type\IntegerType; 
use Symfony\Component\Form\Extension\Core\Type\TextType; 
use Symfony\Component\Form\FormBuilderInterface; 
use Symfony\Component\OptionsResolver\OptionsResolver; 
use Vich\UploaderBundle\Form\Type\VichImageType; 
use ImportBundle\Repository\TaxrefRepository; 
use ImportBundle\Entity\Taxref; 

class ObservationType extends AbstractType 
{ 
    /** 
    * @param FormBuilderInterface $builder 
    * @param array $options 
    */ 
    public function buildForm(FormBuilderInterface $builder, array $options) 
    { 
     $builder 
      ->add('date', DateType::class, array(
       'widget' => 'single_text', 
       'html5' => false, 
       'attr' => array(
        'placeholder' => 'Choisir la date de l\'observation', 
       ) 
      )) 
      ->add('latitude', TextType::class, array(
       'attr' => array(
        'placeholder' => 'Latitude ex : 31.85322' 
       ) 
      )) 
      ->add('longitude', TextType::class, array(
       'attr' => array(
        'placeholder' => 'Longitude ex : 33.55555' 
       ) 
      )) 
      ->add('nombre', IntegerType::class) 

      ->add('imageFile', VichImageType::class, array(
       'required' => false, 
       'allow_delete' => false, // not mandatory, default is true 
       'download_link' => false, // not mandatory, default is true 
       'attr' => array(
        'placeholder' => 'Votre image' 
       ) 
      )) 
      ->add('valide', HiddenType::class) 
      ->add('commentaire', HiddenType::class) 
      ->add('gpsAffiche', HiddenType::class) 
      ->add('meteo', HiddenType::class) 
      ->add('saison', HiddenType::class) 
      ->add('typeSaisie', HiddenType::class) 
      ->add('precipitation', HiddenType::class) 
      ->add('periode', HiddenType::class) 
      ->add('environnement', HiddenType::class) 
      ->add('sensibilite', HiddenType::class) 
      ->add('comportement', HiddenType::class) 
      ->add('species', EntityType::class, array(
       'label' => 'Espèce observée :', 
       'class' => 'ImportBundle\Entity\Taxref', 
       'choice_label' => 'nomVern', 
       'query_builder' => function(TaxrefRepository $qb){ 
        return $qb->distinctTaxref(); 
       } 
      )) 
     ; 
    } 

    /** 
    * @param OptionsResolver $resolver 
    */ 
    public function configureOptions(OptionsResolver $resolver) 
    { 
     $resolver->setDefaults(array(
      'data_class' => 'ObservationBundle\Entity\Observation' 
     )); 
    } 

    /** 
    * @return string 
    */ 
    public function getBlockPrefix() 
    { 
     return 'observationbundle_observation'; 
    } 


} 

そして、私のリポジトリ:

<?php 

namespace ImportBundle\Repository; 

use Doctrine\DBAL\Query\QueryBuilder; 
use Doctrine\ORM\EntityRepository; 
use Doctrine\ORM\Tools\Pagination\Paginator; 
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; 

class TaxrefRepository extends EntityRepository 
{ 
    /** 
    * Pagination liste des especes 
    * @param int $page 
    * @param int $max 
    * @return Paginator 
    */ 
    public function findByPage($page = 1, $max = 8) 
    { 
     if(!is_numeric($page)) { 
      throw new \InvalidArgumentException(
       '$page must be an integer ('.gettype($page).' : '.$page.')' 
      ); 
     } 

     if(!is_numeric($page)) { 
      throw new \InvalidArgumentException(
       '$max must be an integer ('.gettype($max).' : '.$max.')' 
      ); 
     } 

     $dql = $this->createQueryBuilder('t'); 
     $dql->orderBy('t.id', 'DESC'); 

     $firstResult = ($page - 1) * $max; 

     $query = $dql->getQuery(); 
     $query->setFirstResult($firstResult); 
     $query->setMaxResults($max); 

     $paginator = new Paginator($query); 

     if(($paginator->count() <= $firstResult) && $page != 1) { 
      throw new NotFoundHttpException('Page not found'); 
     } 

     return $paginator; 
    } 

    /** 
    * @return \Doctrine\ORM\QueryBuilder 
    */ 
    public function distinctTaxref() 
    { 


     return $this 
      ->createQueryBuilder('t') 
      ->select('t.nomVern') 
      ->distinct(true) 
      ->orderBy('t.nomVern', 'ASC'); 

    } 
} 

はあなたの助けのために事前にありがとうございます、私の悪い英語のため申し訳ありません:/

答えて

0

コードのこの部分を試してみてください

return $this 
     ->createQueryBuilder('t') 
     ->select(array('t.nomVern')) 
     ->distinct(true) 
     ->orderBy('t.nomVern', 'ASC'); 
+0

ありがとうございました。 同じエラーメッセージ:( –

0

私は、EntityTypeを使用しているので、Symfonyはオブジェクトの配列を持つと予想していますが、文字列の配列を生成する単一の列を選択すると考えています。

あなたは、全体としてのオブジェクトを選択してみてくださいことができます:

return $this 
    ->createQueryBuilder('t') 
    ->select('t') 
    ->distinct(true) 
    ->orderBy('t.nomVern', 'ASC'); 

は、この仕事をしていますか?

+0

こんにちは、 私はもはやエラーメッセージを表示していませんが、それ以外は区別がありません 私はquery_builder –