标签:doctrine-orm php symfony inner-join one-to-many
我有跟随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'
目标宣言
/**
....
*
* @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;
解决方法:
您不需要从Session到Goal的引用来执行连接.但是,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');
希望我能正确理解你的问题.
标签:doctrine-orm,php,symfony,inner-join,one-to-many 来源: https://codeday.me/bug/20190729/1569850.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。