我在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),但我找不到任何有用的东西。
答案 0 :(得分:3)
您可以通过addScalarResult
完成。
$rsm=new ResultSetMappingBuilder($this->_em);
$rsm->addRootEntityFromClassMetadata('AppBundle\Entity\Partner','p');
$rsm->addScalarResult('distance', 'distance');
结果将是
array:2 [▼
0 => Partner{...},
distance => xxx
]