sql >> Databáze >  >> RDS >> Mysql

Zobrazte konkrétní pole z databáze v hodnotových a textových polích comboboxu v Symfony2

Chcete-li zobrazit název společnosti namísto jejího ID, použijte property možnost (pro Symfony 2.6 a níže) nebo choice_label možnost (pro Symfony 2.7+) :

Pro Symfony 2.6 a níže:

<?php

namespace Benerite\CompanyBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;

class DepartmentType extends AbstractType
{
    /**
     * @param FormBuilderInterface $builder
     * @param array $options
     */
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('company', 'entity', array(
                'class' => 'CompanyBundle:Company',
                'property' => 'companyName',
            ))  
            ->add('departmentName')
            ->add('departmentStatus')
        ;
    }

    /**
     * @param OptionsResolverInterface $resolver
     */
    public function setDefaultOptions(OptionsResolverInterface $resolver)
    {
        $resolver->setDefaults(array(
            'data_class' => 'Benerite\CompanyBundle\Entity\Department'
        ));
    }

    /**
     * @return string
     */
    public function getName()
    {
        return 'benerite_companybundle_department';
    }
}

Pro Symfony 2.7 a další:

<?php

namespace Benerite\CompanyBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;

class DepartmentType extends AbstractType
{
    /**
     * @param FormBuilderInterface $builder
     * @param array $options
     */
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('company', 'entity', array(
                'class' => 'CompanyBundle:Company',
                'choice_label' => 'companyName',
            ))  
            ->add('departmentName')
            ->add('departmentStatus')
        ;
    }

    /**
     * @param OptionsResolverInterface $resolver
     */
    public function setDefaultOptions(OptionsResolverInterface $resolver)
    {
        $resolver->setDefaults(array(
            'data_class' => 'Benerite\CompanyBundle\Entity\Department'
        ));
    }

    /**
     * @return string
     */
    public function getName()
    {
        return 'benerite_companybundle_department';
    }
}

A mimochodem, ve vaší Twig místo

{{ form_label(form.company) }}
{{ form_widget(form.company) }}

můžete napsat form_row(form.company) .



  1. Spravujte MySQL pomocí phpMyAdmin na Ubuntu 9.10 (Karmic)

  2. Zabraňte rekurzivnímu spouštění v PostgreSQL

  3. Proč vícenásobné dotazy MySql způsobují chybu syntaxe, zatímco samostatně fungují úspěšně?

  4. Jak Sind() funguje v PostgreSQL