Laravel 5: Получить пользователей в возрасте от поля даты

1

У меня проблема с выбором пользователей между диапазоном возраста, когда дата рождения поля в базе данных - это дата типа типа 1989-09-20.

запрос

DB::raw("*, ( 
        3959 * acos( 
        cos(radians(?)) 
        * cos(radians(latitude))
        * cos(radians(longitude) - radians(?)) 
        + sin(radians(?)) 
        * sin(radians(latitude)))
    ) AS distance"))
->having('distance', '<', $distance)
->orderBy("distance")
->setBindings([$lat, $lng, $lat])
->whereHas('user', function($q) {
    $q->whereBetween('date_of_birth',array(Input::get('age_from'),Input::get('age_to')))
      ->where('gender',Input::get('gender'))
      ->where('title','LIKE','%'.Input::get('title').'%');
})
->with('user')
->get();

Я пытаюсь включить атрибут date_of_birth в течение нескольких лет, используя Carbon в модели User, но не работает, потому что по-прежнему принимает в запросе формат даты, а не количество лет.

Модель пользователя

    <?php namespace App;

use Illuminate\Auth\Authenticatable;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Auth\Passwords\CanResetPassword;
use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract;
use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract;

class User extends Model implements AuthenticatableContract, CanResetPasswordContract {

    public function getDateOfBirthAttribute()
    {
        $ca = \Carbon\Carbon::parse($this->attributes['date_of_birth']);

        return $ca->diffInYears();
    }

}

Я надеюсь, что вы можете мне помочь.

Теги:
eloquent
laravel-5

1 ответ

0
Лучший ответ

Я нашел решение и должен использовать этот метод.

$q->whereBetween(DB::raw('TIMESTAMPDIFF(YEAR,users.date_of_birth,CURDATE())'),array(Input::get('age_from'),Input::get('age_to')));

Ещё вопросы

Сообщество Overcoder
Наверх
Меню