1. 程式人生 > >查詢5公里範圍內門店

查詢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];去判斷