簡體   English   中英

使用帶有Symfony2和Doctrine中的多對多關系的QueryBuilder創建查詢

[英]Create a Query using QueryBuilder with a Many-to-Many relation in Symfony2 and Doctrine

晚上好大家!

我有一個小問題。 我想使用Symfony2框架中的自定義DQL查詢來過濾查詢的結果。

這是我的數據庫狀態:

數據庫摘錄

我有返回所需結果的SQL查詢:

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

我只是想在我的QuestionRepository中實現它。

非常感謝您的下一個幫助!

雲公司

您可以使用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)');

謝謝您的回答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();
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM