自动删除 Laravel 中的相关行(Eloquent ORM)
2022-08-30 06:22:50
当我使用以下语法删除行时:
$user->delete();
有没有办法附加各种回调,以便它会自动执行此操作:
$this->photo()->delete();
最好在模型类内部。
当我使用以下语法删除行时:
$user->delete();
有没有办法附加各种回调,以便它会自动执行此操作:
$this->photo()->delete();
最好在模型类内部。
我相信这是雄辩事件(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...
});
}
}
您可能还应该将整个内容放在事务中,以确保引用的完整性。
您实际上可以在迁移中进行此设置:
$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');