【问题标题】:Doctrine queryBuilder: return object not array教义queryBuilder:返回对象而不是数组
【发布时间】:2022-01-24 00:36:32
【问题描述】:

我用教义查询构建器创建了这个查询,我得到的返回是一个数组数组。 我想得到一个对象数组的返回值,这可能吗?

我知道通常 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();

【问题讨论】:

    标签: php symfony object doctrine-orm query-builder


    【解决方案1】:

    你可以用这个:

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

    或者这个:

    return $qb->getQuery()->getArrayResult();
    

    【讨论】:

      【解决方案2】:

      这是不可能的。换句话说,你做错了。

      你告诉 Doctrine 返回一个包含一个实体和一个字符串的集合的集合,所以这就是你得到的。教义不会以此为目标,因为它不知道如何水合这样的结果。

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

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

      【讨论】:

        【解决方案3】:

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

        示例:

        Tourney entity , Invite entity
        
        Invite
            /**
             * @ORM\ManyToOne(targetEntity="Tourney", inversedBy="invites")
             */
            protected $tourneys;
        
        Tourney
            /**
        
             * @ORM\OneToMany(targetEntity="Invite", mappedBy="tourneys", cascade={"persist", "remove"})
             * @ORM\JoinColumn(nullable=true, onDelete="CASCADE")
             */
            protected $invites;
        

        现在您必须查询关系的拥有方(邀请) 它将在 $invites 字段中保存您与 Tourneys 的所有加入对象数据

        它会为您提供对象数组。基于您的查询

        记住 setter $invites 作为 setInvites(Tourney $invites) 和关系的反面 setTourneys(Invite $tourneys)

        【讨论】:

          【解决方案4】:

          只需像这样在getResult() 上添加\Doctrine\ORM\Query::HYDRATE_ARRAY

          $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\ORM\Query::HYDRATE_ARRAY);
          

          【讨论】:

          • 可能想更仔细地阅读这个问题。由于某种原因,他已经得到了一个数组结果。他想要一个对象数组。
          猜你喜欢
          • 2015-10-12
          • 1970-01-01
          • 2020-04-11
          • 2018-07-05
          • 1970-01-01
          • 1970-01-01
          • 2016-11-19
          • 2020-06-29
          相关资源
          最近更新 更多