2
關係,我有以下ER,我需要執行以下使用查詢生成器中的Symfony2-主義查詢(加入僅用於當請求特定的過濾器)主義innerjoin「一對多」與QueryBuilder的
SELECT *
FROM
`session`
INNER JOIN `goal` ON (`session`.`id` = `goal`.`session_id`)
WHERE
`goal`.`name` = 'Background Dx' AND
`session`.`gsite_id` = '66361836'
目標聲明
/**
....
*
* @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;
...
}
會話類不包含對目標
任何參考通過閱讀在線文檔,似乎該準則要求在實體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;
是的,謝謝。在這種特殊情況下,我不關心從實體Session獲取目標,我只使用連接進行數據過濾,所以應該沒問題。 – Alekc