Symfony2表单queryBuilder查找不同对象

Symfony2表单queryBuilder查找不同对象,symfony,doctrine-orm,Symfony,Doctrine Orm,我有一个组织实体 Acme\BaseBundle\Entity\Organization: type: entity ... oneToMany: childOrganizations: targetEntity: Organization mappedBy: parentOrganization manyToOne: parentOrganization: targetEntity: Organization in

我有一个组织实体

Acme\BaseBundle\Entity\Organization:
type: entity
...
oneToMany:
    childOrganizations:
        targetEntity: Organization
        mappedBy: parentOrganization
manyToOne:
    parentOrganization:
        targetEntity: Organization
        inversedBy: childOrganizations
        nullable: true
我有以下表格:

->add('parentOrganization', 'entity', array(
    'class'         => "AcmeBaseBundle:Organization",
    'property'      => 'name',
    'required'      => false,
    'query_builder' => function(EntityRepository $er)
        {
           return $er
             ->createQueryBuilder('o')
             ->select('o')
             ->add('groupBy', 'o.name');
        },
))
然后我只想展示不同的组织。我的意思是如果我有第一,第二和第三个组织。然后我有了第一个组织的表单,我希望在parentOrganization实体字段中只有两个选项(第二个和第三个),但在这种情况下,我有三个选项(第一个可以是第一个的父级)

有没有办法排除与自己的组织连接的可能性


编辑:问题是我在表单类中工作,我不知道如何在这里处理组织对象。这是我的代码:

class OrganizationType extends AbstractType
{
        /**
     * @param FormBuilderInterface $builder
     * @param array $options
     */
    public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder
            ->add('name', null, array('max_length' => 100))
            ->add('type')
            ->add('parentOrganization', 'entity', array(
                    'class'         => "AcmeBaseBundle:Organization",
                    'property'      => 'name',
                    'required'      => false,
                    'query_builder' => function(EntityRepository $er)
                        {
                            return $er->createQueryBuilder('o')
                                ->select('o')
                                ->add('groupBy', 'o.name');
                        }
                ))
            ->add('addresses', 'bootstrap_collection', array(
                'type'                  => new AddressType(),
                'allow_add'             => true,
                'allow_delete'          => true,
                'add_button_text'       => '+',
                'delete_button_text'    => '-',
                'by_reference'          => false,
                'sub_widget_col'        => 9,
                'button_col'            => 3
            ))
    }
    /**
     * @param OptionsResolverInterface $resolver
     */
    public function setDefaultOptions(OptionsResolverInterface $resolver)
    {
         $resolver->setDefaults(array(
            'data_class' => 'Acme\BaseBundle\Entity\Organization'
        ));
    }

    public function getName()
    {
        return 'acme_basebundle_organization';
    }
}

如果您按照doc中的格式创建表单(通过controller的方法
createForm
),则当前实体在
$options['data']
中可用。您的代码如下所示:

$entity = $options['data'];
...
'query_builder' => function(EntityRepository $er) use ($entity)
{
    return $er->createQueryBuilder('o')
        ->select('o')
        ->add('groupBy', 'o.name')
        ->add('where', 'o.id != ?1')
        ->setParameter(1, $entity->getId());
}

您是否尝试将
where
添加到查询中,或者使用
groupBy
在查询生成器中使用
命令?问题是我在表单类中工作,不知道如何使用organization类的参数。谢谢,
$options['data']
正是我要找的。