关闭
douba4275 2017-05-02 07:35
浏览 66
已采纳

Laravel 5.4删除时从数据库中删除记录

I have a reminder table that has a one to many relation on itself, so i have this table:
id: primary key
reminder_id: my foreign key to reminder table
so that i could have a record with key id=1, and many other records that refers to it with reminder_id=1.

I also have a user table, with his id, and a reminder_user to hanlde many to many relationship.
The relation are working good, so that from the user i can retrieve his reminders, from a reminder his children reminder and so on.

The Reminder model:

class Reminder extends Model {

    public function users() {
        return $this->belongsToMany("App\Models\User");
    }

    public function reminder() {
        return $this->belongsTo("App\Models\Reminder");
    }

    public function reminders() {
        return $this->hasMany("App\Models\Reminder");
    }

}

The user model:

class User extends Authenticatable
{
    use Notifiable;

    public function reminders() {
        return $this->belongsToMany("App\Models\Reminder");
    }
}

My problem is that when i update a reminder, the record in my pivot table reminder_user are not deleted.

i tried to create this observer:

namespace App\Observers;

use App\Models\Reminder;

class ReminderObserver {
    public function deleting(Reminder $reminder)
    {
        $reminder->users()->detach();
    }
}

and added it to the appservice provider:

 public function boot()
{
    //...
    Reminder::observe(ReminderObserver::class);
}

but, so far, the records in reminder_user table are not being deleted when i do this transaction:

    DB::transaction(function()use($reminder, $repeated, $user) {
        //delete old reminders
        $reminder->reminders()->delete();
        //add many new reminders
        $reminder->reminders()->saveMany($repeated);
        //save new relation with user
        $user->reminders()->saveMany($repeated);
        //update current reminder
        $reminder->save();
    });

update

As from the answer, the problem is that calling delete() on the query builder doesn't trigger the model observers.

展开全部

  • 写回答

1条回答 默认 最新

  • dongyan1491 2017-05-02 10:13
    关注

    Model observers are only called when the action is taken on the model.

    Your delete call:

    //delete old reminders
    $reminder->reminders()->delete();
    

    This is calling delete() on the query builder, so the models are not created, and therefore the model observers will not be triggered. You will need to load each model and call delete on it individually in order for your model observer to trigger:

    //delete old reminders
    $reminder->reminders()->get()->each(function ($child) {
        $child->delete();
    });
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部