19

ホームページの各投稿のすべてのコメントを取得しようとしています

return 
$this->createQueryBuilder('c')
->select('c')
->from('Sdz\BlogBundle\Entity\Commentaire' ,'c')                
->leftJoin('a.comments' ,'c')->getQuery()->getResult() ;

しかし、私はこのエラーが発生しています

[Semantical Error] line 0, col 58 near '.comments c,': Error:
Identification Variable a used in join path expression but was not defined before.

PS : コメント付きのページ記事が表示されるので、マッピングは正しいです。

4

1 に答える 1

38

それでも問題が発生する場合は、Doctrine2.1ドキュメントの例にある構文を使用したクエリを次に示します。

クエリがカスタムリポジトリメソッドに存在し、「a」は「Article」の省略形であると想定しています。

$em = $this->getEntityManager();
$qb = $em->createQueryBuilder();

$qb->select(array('a', 'c'))
   ->from('Sdz\BlogBundle\Entity\Article', 'a')
   ->leftJoin('a.comments', 'c');

$query = $qb->getQuery();
$results = $query->getResult();

return $results;
于 2011-11-07T01:36:37.240 に答える