查詢5公里範圍內門店
阿新 • • 發佈:2018-12-10
$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];去判斷