Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Wyświetlaj określone pola z bazy danych w polach wartości i tekstowych pola combobox w Symfony2

Aby wyświetlić nazwę firmy zamiast jej identyfikatora, użyj property opcja (dla Symfony 2.6 i poniżej) lub choice_label opcja (dla Symfony 2.7+) :

Dla Symfony 2.6 i poniżej:

<?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';
    }
}

Dla Symfony 2.7 i następnych:

<?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 tak przy okazji, w gałązce zamiast

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

możesz napisać form_row(form.company) .



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Czy jest jakaś korzyść z posiadania automatycznego przyrostu klucza podstawowego w tabeli przestawnej MySQL?

  2. Jak wykryć, że transakcja została już rozpoczęta?

  3. Jak mogę zobaczyć TRANSACTION_REPEATABLE_READ w akcji z JDBC/MySQL?

  4. Limit wierszy wyjaśnij MySQL

  5. Czy program Visual Studio Server Explorer obsługuje niestandardowych dostawców baz danych?