Laravel красноречиво рассчитывает опыт работы - PullRequest
0 голосов
/ 10 ноября 2018

У меня есть пользовательская таблица с опытом работы пользователей:

Schema::create('workplaces', function (Blueprint $table) {
    $table->increments('id');
    $table->unsignedInteger('user_id');
    $table->foreign('user_id')
          ->references('id')
          ->on('users')
          ->onDelete('cascade');
    $table->string('company')->nullable();
    $table->string('position')->nullable();
    $table->string('description')->nullable();
    $table->smallInteger('from')->nullable();
    $table->smallInteger('to')->nullable();
    $table->timestamps();
});

Вот пример данных опыта пользователя:

----------------------------------------------------------
| user_id | company | position | description | from | to |
----------------------------------------------------------
----------------------------------------------------------
|    1    | Google  | Designer | Lorem ipsum | 2018 |null|
----------------------------------------------------------
----------------------------------------------------------
|    1    |  Yahoo  | Designer | Lorem ipsum | 2014 |2017|
----------------------------------------------------------
----------------------------------------------------------
|    1    |Microsoft| Designer | Lorem ipsum | 2004 |2008|
----------------------------------------------------------

В этом примере пользователь с id == 1 имеет 7 лет опыта работы.

2018 - (2017 - 2014) - (2008 - 2004) = 2011

Пользователь в прошлом году работал в 2018 году, и теперь мне нужно вычесть результат из прошлого рабочего года:

2018 - 2011 = 7

Теперь у текущего пользователя 7-летний опыт работы.

Как я могу рассчитать пользовательский опыт работы с помощью Laravel Eloquent?

Ответы [ 2 ]

0 голосов
/ 10 ноября 2018

Я считаю, что вы должны делать такие вычисления на стороне БД.Это будет гораздо более быстрое и гибкое решение.Что если у вас есть 1 миллион пользователей с несколькими записями опыта и вы хотите выбрать 10 самых опытных пользователей?Выполнение таких вычислений на стороне PHP будет крайне неэффективным.

Вот необработанный запрос (Postgres), который может выполнять основную часть работы:

SELECT SUM(COALESCE(to_year, extract(year from current_date)) - from_year) from experiences;

Если вы хотите поигратьи протестируйте другие случаи: http://sqlfiddle.com/#!9/c9840b/3

Другие могут сказать, что это преждевременная оптимизация, но это один вкладыш.Необработанные запросы очень эффективны и должны использоваться чаще.

0 голосов
/ 10 ноября 2018

1) Создайте модель в папке app с именем файла Workplace.php со следующим содержимым:

<?php namespace App;

use Illuminate\Database\Eloquent\Model;

class Workplace extends Model 
{
    protected $table = 'workplaces';

    protected $fillable = ['user_id', 'company', 'position', 'description', 'from', 'to'];

    public $timestamps = true;


    public function user()
    {
        return $this->belongsTo('App\User');
    }

    public function experienceYears() 
    {
      $from = property_exists($this, 'from') ? $this->from : null;
      $to = property_exists($this, 'to') ? $this->to : null;
      if (is_null($from)) return 0;
      if (is_null($to)) $to = $from; // or = date('Y'); depending business logic
      return (int)$to - (int)$from;
    }

    public static function calcExperienceYearsForUser(User $user) 
    {
        $workplaces = 
            self::with('experienceYears')
                  ->whereUserId($user->id)
                  ->get(['from', 'to']);
        $years = 0;
        foreach ($workplaces AS $workplace) {
          $years+= $workplace->experienceYears;
        }
        return $years;
    }
}

2) Используйте его в действии контроллера:

$userId = 1;
$User = User::findOrFail($userId);
$yearsOfExperience = Workplace::calcExperienceYearsForUser($User);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...