Laravel Eloquent:模型删除时的连带删除 1 个改进

删除一条数据库记录的时候希望能自动删除这条记录关联的其它数据,如删除用户后连带删除其创建的文章和图片。

可以用Eloquentdeleting事件来实现:

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

    public function posts()
    {
        return $this->hasMany('Post');
    }

    protected static function boot()
    {
        parent::boot();

        static::deleting(function($user) {
             $user->photos()->delete();
             $user->posts()->delete();
        });
    }
}

MySQL 数据库 Cascade

同样也可以通过 MySQL 数据库的 Cascade 级联删除来实现。迁移文件示例:

<?php

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateTopicsTable extends Migration
{
    public function up()
    {
        Schema::create('topics', function(Blueprint $table) {
            $table->increments('id');
            $table->string('title')->index();
            $table->text('body');
            $table->bigInteger('user_id')->unsigned()->index();
            $table->timestamps();

            // 当 user_id 对应的 users 表数据被删除时,删除词条
            $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
        });
    }

    public function down()
    {
        Schema::drop('topics');
    }
}

当对应的 User 被删除时,该用户的所有 Topic 会连带删除。

本文为 Wiki 文章,邀您参与纠错、纰漏和优化
讨论数量: 20
nff93

不是应该用deleted嘛?

2年前 评论

多对多无法删除

2年前 评论
李大强 8个月前

$user 变量是怎么取值的呢?你这样是得不到值的啊

2年前 评论

要不要用事务呢?

2年前 评论

@fivenull 兄弟 你是怎么解决的 我这里也不能触发

1年前 评论

@JueMeiAlg 你的关联关系定义了没

1年前 评论

@fivenull 我这里定义了关联关系,为什么删不掉所关联的评论和图片

file

1年前 评论

@yibendao 仔细看你的代码,你删除用的deleted,应该是delete

1年前 评论

@fivenull 恩。谢谢啦,刚刚我弄好了

1年前 评论

这样做的话,就不需要外键了?

1年前 评论

又学一招 赞一个

1年前 评论

这个不应该用数据库外键来实现吗?

1年前 评论
Summer (楼主) 1年前
张雷 1年前
张雷

谢谢学习了

1年前 评论

删不了,麻烦大神们可以帮我看看吗?
file

8个月前 评论

file,,各位师兄,我换了static::deleting和static::deleted都不能触发这个事件

5个月前 评论

@hongxin 你的 boot 方法里是static::deleted,删除后就找不到 worksheet 了,也找不到相应的关联模型。原文是 deleting,在删除 worksheet 前先删掉关联模型。

5个月前 评论
阿卡卡 3周前

多级关联是无法删除的哎 :sob:

4个月前 评论

controller层如何引用?

4周前 评论

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!