php+mysql根据传入的位置坐标查询数据库中的客户列表按照位置的由近到远排序

 

/**
 * $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" ;

这样就可以直接查出结果并排序了

你可能感兴趣的:(php,sql)