4

私は次のERを持っており、Symfony2で次のクエリを実行する必要があります-クエリビルダーを使用してDoctrine(結合は特定のフィルターが要求された場合にのみ使用されます)

SELECT *
FROM
  `session`
  INNER JOIN `goal` ON (`session`.`id` = `goal`.`session_id`)
WHERE
  `goal`.`name` = 'Background Dx' AND 
  `session`.`gsite_id` = '66361836'

ER

目標宣言

/**
....
 *
 * @ORM\Table(name="goal")
 * @ORM\Entity
 */
class Goal
{
    ...
    /**
     * @var Session
     *
     * @ORM\ManyToOne(targetEntity="Session")
     * @ORM\JoinColumns({
     *   @ORM\JoinColumn(name="session_id", referencedColumnName="id")
     * })
     */
    private $session;
    ...
}

セッションクラスには、目標への参照が含まれていません

オンラインドキュメントを読むと、教義では、要求された参加を実行するためにエンティティセッションに列が存在する必要があるようです。それは本当にそうですか、それとも別の方法がありますか?

私のQueryBuilder

$rep = $this->em->getRepository(Session::repositoryName);
$qb = $rep->createQueryBuilder("s");

$qb->setMaxResults(50);


//site
if ($params->site != null){
    /** @var Gsite **/
    $site = $params->site;
    $qb->andWhere($qb->expr()->eq("s.site",":site"))->setParameter("site",$site);
}
if (isset($params->goalName)){
    ///SOMETHING
    ....
    ...
    ...
}

$query = $qb->getQuery();
$paginator = new Paginator($query);
return $paginator;
4

1 に答える 1

12

参加を実行するために、セッションから目標への参照は必要ありません。ただし、DoctrineはゴールデータをSessionオブジェクトにマップすることを知りません(したがって、それを取得することはできません)。

$qb->innerJoin('You\YourBundle\Entity\Goal', 'g', Expr\Join::WITH, 's.id = g.session')
->where('g.name = :goalName')->andWhere('s.gsiteId = :gsiteId')
->setParameter('goalName', 'Background Dx')->setParameter('gsiteId', '66361836');

私があなたの質問を正しく理解することを望みます。

于 2012-12-20T14:19:13.363 に答える