在Symfony2和Doctrine中使用具有多对多关系的QueryBuilder创建查询

时间:2014-05-02 21:06:32

标签: php symfony doctrine-orm dql query-builder

大家晚上好!

我有一点问题。我想在Symfony2框架中使用自定义DQL查询过滤查询结果。

这是我的数据库的状态:

Extract of the database

我已经获得了返回所需结果的SQL查询:

SELECT * FROM question WHERE question_id NOT IN (SELECT question_id FROM questions_joueurs WHERE joueur_id = 1)

我只想在我的QuestionRepository中实现它。

非常感谢您的下一次帮助!

CloudCompany

2 个答案:

答案 0 :(得分:3)

您可以使用NOT EXISTS和MEMBER OF来实现此目的。像这样的东西

$qb->select('q.question_id, q.question_intitule')
    ->from('MyBundleNameSpace\Entity\Question', 'q')
    ->where('NOT EXISTS (SELECT 1 FROM MyBundleNameSpace\Entity\Jouer j WHERE j MEMBER OF q.jouers)');

答案 1 :(得分:1)

感谢您的回答FuzzyTree!有用! 我已经对它进行了调整,以便将其放入我的QuestionRepository。

这是我的方法:

public function findNotAnsweredByJoueurs(Partie $partie, $level)
{
    $qb = $this->createQueryBuilder('q');
    $qb->where('q.level < ' . $level);
    foreach($partie->getJoueurs() as $joueur)
    {
        $qb->andWhere('NOT EXISTS (SELECT ' . $joueur->getId() . ' FROM Cloud\Bundle\MoneyDropBundle\Entity\Joueur j WHERE j MEMBER OF q.joueurs)');
    }

    return $qb->getQuery()
              ->getResult();
}