2012-12-20 66 views
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' 

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; 
    ... 
} 

會話類不包含對目標

任何參考

通過閱讀在線文檔,似乎該準則要求在實體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; 

回答

6

你不需要從會議參考目標進行聯接。然而,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'); 

希望我正確理解你的問題。

+0

是的,謝謝。在這種特殊情況下,我不關心從實體Session獲取目標,我只使用連接進行數據過濾,所以應該沒問題。 – Alekc