查询5公里范围内门店

$mylat = $data['lat'];

$mylng = $data['lng'];

$maxRange = db(\tname::config)->where('uid', WID)->value('location_range');

$where['2 * asin(sqrt(pow(sin((v.lat * pi() / 180 - '.$mylat.' * pi() / 180) / 2),2) + cos(v.lat * pi() / 180) * cos('.$mylat.' * pi() / 180) * pow(sin((v.lng * pi() / 180 - '.$mylng.' * pi() / 180) / 2),2))) * 6378.137'] = ['elt',$maxRange];

$nearPeopleList = $callingModel->alias('a')

    ->join('wechat_' . \tname::vip . ' v', 'v.openid=a.openid', 'left')

    ->field("a.*,2 * asin(sqrt(pow(sin((v.lat * pi() / 180 - $mylat * pi() / 180) / 2),2) + cos(v.lat * pi() / 180) * cos($mylat * pi() / 180) * pow(sin((v.lng * pi() / 180 - $mylng * pi() / 180) / 2),2))) * 6378.137 as distance")

    ->where($where)

    ->order('distance asc')

    ->paginate(10, false, ['page' => $data['page']])->each(function ($item, $key) use ($data) {

        $item['distance'] = round($item['distance'],2);

        return $item;

    });
当用经纬度写在where条件里面的时候,如果是联查表不可以用filed的别名区筛选,sql不识别,只能用$where['2 * asin(sqrt(pow(sin((v.lat * pi() / 180 - '.$mylat.' * pi() / 180) / 2),2) + cos(v.lat * pi() / 180) * cos('.$mylat.' * pi() / 180) * pow(sin((v.lng * pi() / 180 - '.$mylng.' * pi() / 180) / 2),2))) * 6378.137'] = ['elt',$maxRange];去判断

 

猜你喜欢

转载自blog.csdn.net/weixin_39984546/article/details/84935618