自动删除 Laravel 中的相关行(Eloquent ORM)

当我使用以下语法删除行时:

$user->delete();

有没有办法附加各种回调,以便它会自动执行此操作:

$this->photo()->delete();

最好在模型类内部。


答案 1

我相信这是雄辩事件(http://laravel.com/docs/eloquent#model-events)的完美用例。您可以使用“删除”事件进行清理:

class User extends Eloquent
{
    public function photos()
    {
        return $this->has_many('Photo');
    }

    // this is a recommended way to declare event handlers
    public static function boot() {
        parent::boot();

        static::deleting(function($user) { // before delete() method call this
             $user->photos()->delete();
             // do the rest of the cleanup...
        });
    }
}

您可能还应该将整个内容放在事务中,以确保引用的完整性。


答案 2

您实际上可以在迁移中进行此设置:

$table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');

资料来源:http://laravel.com/docs/5.1/migrations#foreign-key-constraints

您还可以为约束的“删除时”和“更新时”属性指定所需的操作:

$table->foreign('user_id')
      ->references('id')->on('users')
      ->onDelete('cascade');

推荐