Laravel getDirty和getOriginal在更新时给出相同的值

Chr*_*hvh 6 php laravel eloquent laravel-5.4

运用 Laravel 5.4

我有一个Job模型,其上有一个enum字段,具有不同的状态.这些状态在许多不同的地方发生变化.我制作了一个JobHistory模型和迁移来跟踪这些变化.

在我的工作模型中,我定义了新的laravel 5.4跟踪雄辩事件的方式:

/**
 * The events that should be fired for eloquent actions
 *
 * @var array
 */
protected $events = [
    'updating' => JobChangedStatus::class
];
Run Code Online (Sandbox Code Playgroud)

状态更改如下所示:

/**
 * Change the job status
 *
 * @param $status
 */
public function changeStatus($status)
{
    $this->update([
        'status' => $status,
    ]);
}
Run Code Online (Sandbox Code Playgroud)

EventServiceProvider:

'App\Events\Jobs\JobChangedStatus' => [
  'App\Listeners\Jobs\CreateJobHistory',
],
Run Code Online (Sandbox Code Playgroud)

CreateJobHistory Listener:

$job = $event->job;

$jobHistory = new JobHistory();
$jobHistory->old_status = $job->getOriginal('status');
$jobHistory->new_status = $job->status;
$jobHistory->job()->associate($job);
$jobHistory->executor()->associate(Auth::user());
$jobHistory->save();
Run Code Online (Sandbox Code Playgroud)

当我将工作状态从例如New改为In_progress

我的JobHistory表格如下所示:

在此输入图像描述

所以new_status和old_status都给出了旧值.我尝试使用$job->getDirty()但是当我打印它时它只返回一个空数组.

我究竟做错了什么?

Mik*_*son 0

通常我会在Observer中实现这一点。看到这样的事件/监听器设置感觉有点尴尬。

在你的AppServiceProvider.php

public function boot()
{
    App\Job::observe(App\Observers\JobObserver::class);
}
Run Code Online (Sandbox Code Playgroud)

然后在App\Observers\JobObserver.php

use App\Job;
use App\JobHistory;

class JobObserver{
    public function updating(Job $job)
    {
        $jobHistory = new JobHistory();
        $jobHistory->old_status = $job->getOriginal('status');
        $jobHistory->new_status = $job->status;
        $jobHistory->job()->associate($job);
        $jobHistory->executor()->associate(Auth::user());
        $jobHistory->save();
    }
}
Run Code Online (Sandbox Code Playgroud)

对于雄辩的模型来说,使用观察者是最有意义的(只是我的观点)。我用来监听邮件事件、工作事件、可能的通知等的事件/监听器模型。

这可能对您的情况有所帮助的另一个原因是,如果事件正在排队而不是同步运行,您最终会遇到竞争条件,并且大多数情况下模型将被保存,这就是为什么getDirty()没有键的原因。对于观察者,操作始终同步运行,您不会遇到计时问题。