一般情况下我都会使用 MySQL 的外键约束来删除管理的记录。在 Laravel 中这很容易做到,你只需要在 Migration 文件里的某个表字段上设置一个 onDelete 函数即可神奇般地自动删除。

但是,当你开启软删除后,该怎么处理呢?你只是更新了 deleted_at 字段,你的数据库没接收到 真正的 删除某条记录的命令,所以你的关联数据纹丝不动,变成了垃圾数据。

  • 我的解决方案是在模型中使用事件和数组来设置联动删除,只需要两行代码,即可做到联动删除和还原删除。
  • 这里我们利用一个叫做“Laravel Soft Cascade”的包

Laravel Soft Cascade包介绍

https://github.com/Askedio/laravel-soft-cascade

Laravel Soft Cascade 是一个可轻松管理关联模型间的 软删除 联动删除和恢复的包。

包的提供者 Will Bowman 还特地为 这个包 写了一篇文章,其中提及了当你已经配置了软删除,却想级联删除相关模型的外键约束时会发送什么情况:

操作流程

我的解决方案是在模型中使用事件和数组来设置联动删除,只需要两行代码,即可做到联动删除和还原删除。

  1. 准备开始,使用 composer 安装包,同时 Laravel 的自动加载特性会帮你搞定剩余部分:

    1. composer require askedio/laravel-soft-cascade
  2. 使用这个包,你可以启动 SoftCascadeTrait 并配置哪些关系应该软级联删除:

    1. use \Askedio\SoftCascade\Traits\SoftCascadeTrait;
    2. protected $softCascade = ['profiles'];
  3. 定义关系后,你可以在模型是触发一个删除或恢复, 并且将与模型一起恢复或(软)删除相关模型:

    1. User::first()->delete();
    2. User::withTrashed()->first()->restore();

参考文献

原文地址:https://laravel-news.com/cascading-soft-deletes

译文地址:https://laravel-china.org/topics/10965/soft-delete-linkage-solution-for-laravel-correlation-model-extended-recommendation

您的支持是对我最大的鼓励!

分类: laravel

标签: