一般情况下我都会使用 MySQL 的外键约束来删除管理的记录。在 Laravel 中这很容易做到,你只需要在 Migration 文件里的某个表字段上设置一个 onDelete 函数即可神奇般地自动删除。
但是,当你开启软删除后,该怎么处理呢?你只是更新了 deleted_at 字段,你的数据库没接收到 真正的 删除某条记录的命令,所以你的关联数据纹丝不动,变成了垃圾数据。
- 我的解决方案是在模型中使用事件和数组来设置联动删除,只需要两行代码,即可做到联动删除和还原删除。
- 这里我们利用一个叫做“Laravel Soft Cascade”的包
Laravel Soft Cascade包介绍
https://github.com/Askedio/laravel-soft-cascade
Laravel Soft Cascade 是一个可轻松管理关联模型间的 软删除 联动删除和恢复的包。
包的提供者 Will Bowman 还特地为 这个包 写了一篇文章,其中提及了当你已经配置了软删除,却想级联删除相关模型的外键约束时会发送什么情况:
操作流程
我的解决方案是在模型中使用事件和数组来设置联动删除,只需要两行代码,即可做到联动删除和还原删除。
-
准备开始,使用 composer 安装包,同时 Laravel 的自动加载特性会帮你搞定剩余部分:
composer require askedio/laravel-soft-cascade
-
使用这个包,你可以启动 SoftCascadeTrait 并配置哪些关系应该软级联删除:
use \Askedio\SoftCascade\Traits\SoftCascadeTrait; protected $softCascade = ['profiles'];
-
定义关系后,你可以在模型是触发一个删除或恢复, 并且将与模型一起恢复或(软)删除相关模型:
User::first()->delete(); User::withTrashed()->first()->restore();