Doctrine queryBuilder:返回对象而不是数组

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Doctrine queryBuilder:返回对象而不是数组相关的知识,希望对你有一定的参考价值。

我用doctrine querybuilder创建了这个查询,返回的是一个数组数组。我想获得一个对象数组的返回,这可能吗?

我知道通常Doctrine会返回一个实体的对象,因为我有一个内连接来从另一个表中获取它返回数组的名称。

提前致谢。

   $qb->select('u', 'h.name')
        ->from('AppBundle:UserHose', 'u')
        ->innerJoin('AppBundle:Hose', 'h', 'WITH', 'u.hoseId = h.id')
        ->where('u.userId = :userId')
        ->orderBy('u.id', 'DESC')
            ->setParameter('userId', $userId); 


    return $qb->getQuery()->getResult();
答案

这种方式不可能。换句话说,你做错了。

你告诉Doctrine返回一个包含实体和字符串的集合集合,这就是你得到的。由于它不知道如何补充这样的结果,因此学说不会成为一个对象。

[
  [entity, string],
  [entity, string],
  ....
]

如果您希望仅接收对象集合,则需要创建一个具有两个字段(相关实体和字符串属性)的新实体,然后使用ResultSet mapping来对其进行水合。

另一答案

你可以用这个:

return $qb->getQuery()->getResult(Query::HYDRATE_ARRAY);

或这个:

return $qb->getQuery()->getArrayResult();
另一答案

如果你想要对象数组,你必须在实体之间设置关系,并通过关系的拥有方创建一个查询。

例:

Tourney entity , Invite entity

Invite
    /**
     * @ORMManyToOne(targetEntity="Tourney", inversedBy="invites")
     */
    protected $tourneys;

Tourney
    /**

     * @ORMOneToMany(targetEntity="Invite", mappedBy="tourneys", cascade={"persist", "remove"})
     * @ORMJoinColumn(nullable=true, onDelete="CASCADE")
     */
    protected $invites;

现在你必须向关系的拥有方(Invite)进行查询,并且它将在Tour邀请中保存所有你的连接对象数据$ invites

它为您提供了一系列对象。根据您的查询

记住setter $ invites as set Invites(Tourney $ invites)和by side side of relation set Tourneys(Invite $ tourneys)

另一答案

只需在DoctrineORMQuery::HYDRATE_ARRAY上添加getResult()就像这样

$qb->select('u', 'h.name')
   ->from('AppBundle:UserHose', 'u')
   ->innerJoin('AppBundle:Hose', 'h', 'WITH', 'u.hoseId = h.id')
   ->where('u.userId = :userId')
   ->orderBy('u.id', 'DESC')
   ->setParameter('userId', $userId); 

return $qb->getQuery()->getResult(DoctrineORMQuery::HYDRATE_ARRAY);

以上是关于Doctrine queryBuilder:返回对象而不是数组的主要内容,如果未能解决你的问题,请参考以下文章

doctrine queryBuilder

在 Doctrine DBAL 中重用 QueryBuilder

学说:ORM QueryBuilder 或 DBAL QueryBuilder

在 Doctrine QueryBuilder 中计算行数

在 Doctrine QueryBuilder 中计算行数

Doctrine preLoad Listener 在执行前操纵 QueryBuilder