1

我正在寻找方法,如何将查询生成器结果转换为关联数组。但我需要的是包含来自另一个表的关系数据。如果我使用 getArrayResult() 方法,它会给我一个数组,但没有外键。我需要嵌套数组中包含的外键以及关联数据库表的数据。 编辑: 这是我的代码:

$qb = $this->_em->createQueryBuilder();
$qb->select('p');
$qb->from('XXX\MyBundle\Entity\Entity1', 'p');

$qb->leftJoin('p.FK1','u');
$qb->andWhere('u.Attr1 = :attr1');
$qb->setParameter('attr1', $appId);
$qb->andWhere('u.Attr2 IS NULL');
$qb->leftJoin('u.FK2', 'v');
$qb->andWhere('v.Attr3 = :attr3');
$qb->andWhere('v.Attr4 IS NULL');
$qb->setParameter('attr3', $userId);


$result = $qb->getQuery()->getArrayResult();

由于 SOAP,我需要这种转换。它不能将复杂对象作为实体的嵌套对象返回。

4

1 回答 1

2

首先,您需要在 Entity1Repository.php 中编写此函数

由于您使用的是 createQueryBuilder() 方法,因此您不需要使用 select 和 from 方法。在您的示例中,您正在编写连接,但您并没有要求查询返回这些连接。

试试这个代码:

<?php

namespace XXX\\MyBundle\Entity;

use Doctrine\ORM\EntityRepository;

class Entity1Repository extends EntityRepository
{
    public function getEntityWithJoins()
    {
        return $this
            ->createQueryBuilder('p')
            ->addSelect('u')
            ->addSelect('v')
            ->leftJoin('p.FK1','u')
            ->andWhere('u.Attr1 = :attr1')
            ->setParameter('attr1', $appId)
            ->andWhere('u.Attr2 IS NULL')
            ->leftJoin('u.FK2', 'v')
            ->andWhere('v.Attr3 = :attr3')
            ->andWhere('v.Attr4 IS NULL')
            ->setParameter('attr3', $userId);
            ->getQuery()
            ->getArrayResult();
    }
}
于 2013-03-17T14:24:57.417 回答