php获取附近的商家

在做项目的时候,有时候需要获取用户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

支付宝扫码打赏 微信扫码打赏

如果本文对你有帮助,欢迎打赏本站

喜欢 ()or分享
    匿名评论
  • 评论
人参与,条评论