在做项目的时候,有时候需要获取用户5公里之内的商家,这个时候可以使用mysql的空间坐标查询
/* *我附近的商家 */ public function myNearShop(){ $slat = input('lat'); $slng = input('lng'); $sql = "SELECT *, ROUND(6378.138*2*ASIN(SQRT(POW(SIN(($slat*PI()/180-lat*PI()/180)/2),2)+COS($slat*PI()/180)*COS(lat*PI()/180)*POW(SIN(($slng*PI()/180-lng*PI()/180)/2),2)))) AS juli FROM ore_shop where status=2 HAVING juli <= 5"; $shop_list = Db::query($sql); if(!empty($shop_list)){ return json_encode(array('status'=>1,'msg'=>"获取成功!",'result'=>$shop_list)); } return json_encode(array('status'=>0,'msg'=>"附近没有商家!",'result'=>null)); }
转载自:https://blog.csdn.net/sluckyboy/article/details/82655696
如果本文对你有帮助,欢迎打赏本站