我想使用给定距离过滤数据库中的用户。
在数据库中,我有城市,经度和纬度。现在我们应该在城市和距离该城市的距离写作,脚本应该返回给定公里内该城市附近的所有用户。
我怎样才能实现这一目标?
这是我的代码:
if ($request->has('city')) {
$from_latitude = app('geocoder')->geocode($data['residence'])->get()->first()->getCoordinates()->getLatitude();
$from_longitude = app('geocoder')->geocode($data['residence'])->get()->first()->getCoordinates()->getLongitude();
$user->whereHas('user_data', function($query) use ($request) {
$raw = \DB::raw('ROUND ( ( 6371 * acos( cos( radians('.$from_latitude.') ) * cos( radians( latitude ) ) * cos( radians( longitude ) - radians('.$from_longitude.') ) + sin( radians('.$from_latitude.') ) * sin( radians( latitude ) ) ) ) ) AS distance');
return $query->select('*')->addSelect($raw)->orderBy( 'distance', 'ASC' )->groupBy('distance')->having('distance', '<=', $distance);
});
}
答案 0 :(得分:5)
我无法理解你的问题。所以我在我的一个项目中做到了这一点,希望你从这个答案中得到一些想法
$latitude = 30.9193;
$longitude = 75.8309;
$users = DB::table('users');
// for km
$users->whereRaw("( 6371 * acos ( cos ( radians(".$latitude.") ) * cos( radians( latitude ) ) * cos( radians( longitude ) - radians(".$longitude.") ) + sin ( radians(".$latitude.") ) * sin( radians( latitude ) ) ) <=3.3)")->get();
// for miles
$users->whereRaw("( 3959 * acos ( cos ( radians(".$latitude.") ) * cos( radians( latitude ) ) * cos( radians( longitude ) - radians(".$longitude.") ) + sin ( radians(".$latitude.") ) * sin( radians( latitude ) ) ) <=3.3)")->get();
希望它能帮到你!