duanji7182 2017-07-13 09:49
浏览 60
已采纳

使用querybuilder在另一个内部构建查询?

I got 2 tables User and Group; each object Group got an array members[] that points to some instances of User.

I need to build this same query with QueryBuilder :

SELECT (users instances) FROM User
WHERE (users instances) IN (SELECT Group.members from Group WHERE group.id = $someId)

How can I achieve that?

  • 写回答

2条回答 默认 最新

  • duan0802 2017-07-13 10:14
    关注

    You have to make 2 querybuilders:

    $qb2 = $this->em->createQueryBuilder('group')
                ->select('group.members')
                ->where('group.id = $someId');
    
    $qb = $this->em->createQueryBuilder('user')
               ->select(user instances)
               -where($qb->expr()->in('user instances', $qb2->getDQL());
    

    it will give you the idea how it works. Of course you have to adjust this code to yours.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?