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']
正是我要找的。