在Doctrine2中的本机查询中获取未映射的字段

时间:2016-01-01 12:37:59

标签: doctrine-orm symfony

我在Symfony3中有一个带有Doctrine2的功能,它使用纬度和经度搜索最近的伙伴:

public function findNearestPartner($lat,$lng) {

    $rsm=new ResultSetMappingBuilder($this->_em);
    $rsm->addRootEntityFromClassMetadata('AppBundle\Entity\Partner','p');

    $sqlQuery="SELECT p.*, (6371 * acos(cos(radians(:lat)) * cos(radians(p.latitude)) * cos(radians(p.longitude) - radians(:lng)) + sin(radians(:lat)) * sin(radians(p.latitude)))) AS distance
    FROM sp_partner p
    ORDER BY distance ASC
    LIMIT 0,1";

    $query=$this->_em
        ->createNativeQuery($sqlQuery,$rsm)
        ->setParameter('lat',$lat)
        ->setParameter('lng',$lng)
    ;

    return $query->getOneOrNullResult();
}

如你所见,我得到最近的合作伙伴实体 - 但也有“距离”字段,我没有回复(但它会非常有用)。有没有办法获得这个领域的价值? 我在文档中读到了{http://docs.doctrine-project.org/projects/doctrine-orm/en/latest/reference/native-sql.html),但我找不到任何有用的东西。

1 个答案:

答案 0 :(得分:3)

您可以通过addScalarResult完成。

$rsm=new ResultSetMappingBuilder($this->_em);
$rsm->addRootEntityFromClassMetadata('AppBundle\Entity\Partner','p');
$rsm->addScalarResult('distance', 'distance');

结果将是

array:2 [▼
  0 => Partner{...},
  distance => xxx
]