/**
* $lat:用户纬度
* $lng:用户经度
* $as_name:查询出来的SQL字段名称
*/
get_distance_sql($lat,$lng,$as_name='distance')
{
return sprintf('round(6371*sqrt( pow((PI()*(abs(`lat`-%f))/180) * cos(PI()*(`lat`+%f)/360),2)
+ pow((PI()*abs(`lng`-%f)/180),2)),4) as %s',$lat,$lat,$lng,$as_name);
}
具体SQL如下:
/**
* shop_id 商家id
*/
$sql = "SELECT shop_id,lat,lng,".get_distance_sql( $lat,$lng)." FROM table_name
WHERE distance< = ".$distance." ORDER BY distance ASC" ;
这样就可以直接查出结果并排序了