php - 选择给定公里内的用户

标签 php laravel

我想使用给定距离过滤数据库中的用户。

在数据库中我有城市、经度和纬度。现在我们应该以城市和距该城市的距离的形式编写,脚本应返回给定公里内该城市附近的所有用户。

我怎样才能实现这一目标?

这是我的代码:

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);
   });
}

最佳答案

我无法理解你的问题。所以我在我的一个项目中做到了这一点,希望你能从这个答案中得到一些想法

$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();

希望对您有帮助!

关于php - 选择给定公里内的用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47430406/

相关文章:

php - 在 PHP 中混合引号

php - Laravel Eloquent whereDoesntHave() 文档让我感到困惑

php - Laravel redirect::route 在页面加载之间显示一条消息

php - 如何使 Laravel (Blade) 文本字段只读

php - 当父级在一对多关系中没有子级时,我在检查时会收到非对象错误

带有 MySQL 的 PHP PDO 准备删除语句在 Ajax 调用中失败

php - 如何使用 exec() 调试从 php 调用的 C++ 代码

php - Laravel 基于角色处理 trait 中的用户重定向

php - 仅在第一个结果中显示/隐藏 mysql 结果函数

php - 将数据库值与另一个表中的行数进行比较