php+mysql根据传入的位置坐标查询数据库中的客户列表按照位置的由近到远排序
发布时间:2022-09-28 23:51:46 354
相关标签: # php# sql
/**
* $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" ;
这样就可以直接查出结果并排序了
文章来源: https://blog.51cto.com/u_13646572/5361473
特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报