在 Symfony2 中,我在用户和角色之间有一个多:多的关系。我正在尝试获取未链接到该ROLE_SUPER_ADMIN
角色的所有用户的列表。
在迁移到 Symfony2/Doctrine 之前,我已经通过一个简单的NOT IN
sql 查询实现了这一点,但在我的一生中,我无法用学说实现同样的效果。
这是我正在尝试的:
$em = $this->getDoctrine()->getManager();
$qb = $em->createQueryBuilder();
$qb2 = $qb;
$dql = $qb->select('sa.id')
->from('AcmeAdminBundle:User', 'sa')
->leftJoin('sa.roles', 'r')
->andWhere('r.role = :role')
->getDQL();
$result = $qb2->select('u')
->from('AcmeAdminBundle:User', 'u')
->where($qb2->expr()->notIn('u.id', $dql))
->setParameter('role', 'ROLE_SUPER_ADMIN')
$users = $result->getQuery()->getResult();
但这是错误:
[Semantical Error] line 0, col 140 near 'sa LEFT JOIN':
Error: 'sa' is already defined.
这是输出:
SELECT u
FROM AcmeAdminBundle:User sa
LEFT JOIN sa.roles r, AcmeAdminBundle:User u
WHERE u.id NOT IN (
SELECT sa.id
FROM AcmeAdminBundle:User sa
LEFT JOIN sa.roles r
WHERE r.role = :role
)
不知道为什么它会这样输出,因为它不应该执行LEFT JOIN
两次,我怀疑它与拥有两个 QueryBuilder 实例有关,但可能完全是另外一回事。