我有两个类User
和Role
,我需要创建一个QueryBuilder
返回具有该ROLE_PROVIDER
角色的用户的查询。我需要在 Symfony 2 中的实体表单字段中使用它。在表单类定义中,我对提到的字段有以下片段:
$builder->add('provider', 'entity', array(
'class' => 'ElCuadreAccountBundle:User',
'property' => 'username',
'query_builder' => function(UserRepository $ur) {
return $ur->getUsersByRoleQB('ROLE_PROVIDER');
},
'required' => true,
));
然后在我的自定义中,UserRepository
我有以下函数,它应该返回一个QueryBuilder
对象:
public function getUsersByRoleQB($role) {
$qb = $this->createQueryBuilder('u');
return $qb->join('u.roles','r')
->where($qb->expr()->in('r.role',$qb->expr()->literal($role)))
->orderBy('u.username', 'ASC');
}
当然这不起作用,但我粘贴它以说明我的需求。
我一直在环顾四周,似乎 Doctrine2 不支持通过关联进行本地过滤。在此页面中,他们这样说,并建议使用DQL
这种过滤。我的问题是我还没有找到如何从一个句子中制造一个QueryBuilder
对象。DQL
如果您也可以向我提供正确的DQL
查询,我将非常感激...
谢谢你的帮助!