php - Laravel 按与用户的距离搜索

标签 php mysql laravel search distance

嘿,所以我有一个完美的搜索表单,除了与用户的距离之外,我有点迷失了如何让它工作,但这就是我所拥有的

public static function Search($input)
{
    $date = \Carbon\Carbon::now()->subMinute(30);
    $query = User::rightJoin('user_profiles', 'users.id', '=', 'user_profiles.user_id');

    if (isset($input ['minAge']) && $input['minAge']) {
        $minAge = $input['minAge'];
        $maxDate = \Carbon\Carbon::today()->subYears($minAge)->endOfDay();
    }

    if (isset($input ['maxAge']) && $input['maxAge']) {
        if ($input['maxAge'] < $input['minAge']) {
            $maxAge = $input['minAge'];
        }
        else {
            $maxAge = $input['maxAge'];
        }
        $minDate = \Carbon\Carbon::today()->subYears($maxAge + 1);
    }

    if (isset($input['u']) && $input['u'])
        $query->where('users.username', '=', $input['u']);
    if (isset($input['p'])  && $input['p'])
        $query->where('user_profiles.postcode', '=', $input ['p']);
    if (isset($input['o1']) && $input['o1'])
        $query->where('users.last_online','>=',$date);
    if (isset($input['o2']) && $input['o2'])
        $query->whereNotNull('user_profiles.avatar');
    if (isset($input ['o3']) && $input['o3'])
        $query->orderBy('users.type', 'ASC');
    if (isset($input ['minAge']) && $input['minAge'])
        $query->whereBetween('user_profiles.dob', [$minDate, $maxDate]);
    if (isset($input ['g']))
        $query->whereIn('user_profiles.gender',$input ['g']);
    if (isset($input ['d']))
        $query->select('user_profiles.lat, user_profiles.long
            ( 6371 * acos( cos( radians(?) ) *
                       cos( radians( lat ) )
                       * cos( radians( long ) - radians(?)
                       ) + sin( radians(?) ) *
                       sin( radians( lat ) ) )
                     ) AS distance'
            )
        ->having("distance", "<", "?")
        ->orderBy("distance")
        ->setBindings([$input['lat'], $input['long'], $input['lat'],  $input['d']]);


    $query->orderBy('users.last_online', 'DESC');
    $users = $query->paginate(10);
    return $users;
}

它有 if (isset($input ['d'])) 这是我选择与用户距离的输入,选项设置为 5 代表 5 公里,10 代表 10 公里等等。

一旦我搜索查询它说列距离不存在并且它不存在,我认为计算用户经度和纬度的整个数学设置距离?

最佳答案

您需要使用 DB::raw() 来环绕代码。

您似乎从此处复制了代码,但删除了原始语句:http://laravel.io/forum/04-23-2014-convert-this-geolocation-query-to-query-builder-for

关于php - Laravel 按与用户的距离搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36381131/

相关文章:

php - 在php和mysql中上传后找不到文件

PHP & do/while 循环内存泄漏

php - Htaccess : Trigger php or write to log

javascript - 加密 Web 应用程序和服务器之间的数据

php - 对于laravel多态多态关系,如何添加数据库约束?

php - 来自带有 RequestBody 的 swagger post 调用的空响应

javascript - Particles Js Canvas 显示在页面的最底部

php - 使用 jQuery、AJAX、MySQL 的 TreeView

Javascript - 如何从 MQTT 将变量值插入数据库

mysql - 如何在 MySQL 中选择最近 30 天的日期?