【问题标题】:Create a Query using QueryBuilder with a Many-to-Many relation in Symfony2 and Doctrine在 Symfony2 和 Doctrine 中使用具有多对多关系的 QueryBuilder 创建查询
【发布时间】:2014-05-02 21:06:32
【问题描述】:

大家晚上好!

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

这是我的数据库的状态:

我有返回所需结果的 SQL 查询:

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

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

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

云公司

【问题讨论】:

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


    【解决方案1】:

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

    【讨论】:

      【解决方案2】:

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

      【讨论】:

      • foreach 不是必需的,事实上您在每次迭代时都会覆盖 where 条件(在第一个 'where' 之后堆叠 where 条件使用 'andWhere')。
      猜你喜欢
      • 1970-01-01
      • 2014-12-20
      • 1970-01-01
      • 1970-01-01
      • 2014-09-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多