首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >关于不相关实体的理论

关于不相关实体的理论
EN

Stack Overflow用户
提问于 2016-08-02 14:06:54
回答 1查看 461关注 0票数 0

有没有办法这么做。我越来越困惑于尝试不同的事情。

我有一个实体会议可以有个地方。地方与城市有着多到一种关系。

在我的查询中,我试图检索城市信息,但似乎无法在相同的地方检索结果。这是使用的查询:

代码语言:javascript
复制
$qbt = $this->_em->createQueryBuilder();
$qbt
    ->select('conference', 'diffusion', 'speaker', 'placediff', 'confcity')
    ->from('AppBundle:Conference', 'conference')
    ->leftJoin('conference.diffusion', 'diffusion')
    ->leftJoin('conference.speaker','speaker')
    ->leftJoin('conference.place','placediff')
    ->leftJoin('AppBundle:City', 'confcity', 'WITH', 'confcity.id = placediff.city');

return $qbt
    ->getQuery()
    ->setHint(\Doctrine\ORM\Query::HINT_INCLUDE_META_COLUMNS, true)
    ->useQueryCache(true)
    ->useResultCache(true, 3600)
    ->getArrayResult();

这就是回报,目前只有一次会议。希望有第二个数组在里面,不过。

对如何做到这一点有什么想法吗?非常感激~

(UPDATE)在此期间,我切换到了原始sql查询,但实际上正在寻找一种使用dql进行此操作的方法。

代码语言:javascript
复制
    public function rawConf()
    {
        $conn = $this->getEntityManager()->getConnection();
        $sql = 'SELECT
  c0_.id AS id,
  c0_.startAt AS startat,
  c0_.comment AS comment,
  d1_.id AS diffusion_id,
  d1_.hour AS diffusion_hour,
  s2_.id AS speaker_id,
  c0_.place_id AS place_id,
  c0_.sponsor_id AS sponsor_id,
  c0_.tour_id AS tour_id_8,
  d1_.movie_id AS diffusion_movie_id,
  s2_.contact_id AS speaker_contact_id,
  c6_.name AS ville_name,
  c6_.postal AS ville_post,
  c6_.department as ville_depart
FROM
  conference c0_
  LEFT JOIN conference_diffusion c3_ ON c0_.id = c3_.conference_id
  LEFT JOIN diffusion d1_ ON d1_.id = c3_.diffusion_id
  LEFT JOIN conference_speaker c4_ ON c0_.id = c4_.conference_id
  LEFT JOIN speaker s2_ ON s2_.id = c4_.speaker_id
  LEFT JOIN place p5_ ON c0_.place_id = p5_.id
  LEFT JOIN city c6_ ON (c6_.id = p5_.city_id)';

        $stmt = $conn->prepare($sql);

        $stmt->execute();

        return $stmt->fetchAll();

    }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-08-03 08:31:11

您应该从" Place“中获取"city”,因为"$city“是Place实体的属性。尝试这个简化的查询以查看它是否有效:

代码语言:javascript
复制
$qbt = $this->_em->createQueryBuilder();
$qbt
    ->select('conference')
    ->addSelect('place')
    ->addSelect('city')
    ->from('AppBundle:Conference', 'conference')
    ->innerJoin('conference.place', 'place')
    ->innerJoin('place.city', 'city')
;

如果有效的话--如果需要的话,可以轻松地添加更多的连接。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38722752

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档