关于与查询构建器的“一对多”关系的教义内连接

Posted

技术标签:

【中文标题】关于与查询构建器的“一对多”关系的教义内连接【英文标题】:Doctrine innerjoin on "one to many" relationship with querybuilder 【发布时间】:2012-12-07 21:36:06 【问题描述】:

我有以下 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;
    ...

会话类不包含对目标的任何引用

通过阅读在线文档,学说似乎需要在实体 Session 上存在列来执行请求的加入。真的是这样吗,还是有别的办法?

我的查询生成器

$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;

【问题讨论】:

【参考方案1】:

您不需要从 Session 到 Goal 的引用来执行加入。但是,Doctrine 不知道将 Goal 数据映射到 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');

希望我能正确理解您的问题。

【讨论】:

好的,谢谢。在这种特殊情况下,我不关心从实体 Session 中获取目标,我只使用 join 进行数据过滤,所以应该没问题。

以上是关于关于与查询构建器的“一对多”关系的教义内连接的主要内容,如果未能解决你的问题,请参考以下文章

教义没有在教义上创建一对多关系:模式:更新

关于多对多分类器的文献

134 MySQL多表查询

MyBatis的对象关系映射---一对多等值连接策略★★★★★

MyBatis的对象关系映射---一对多N+1策略★★★★★

关于一对多,多对多的多表查询的控制