[扩展推荐] Laravel 关联模型的软删除联动解决方案
Laravel Soft Cascade 是一个可轻松管理关联模型间的 软删除 联动删除和恢复的包。
包的提供者 Will Bowman 还特地为 这个包 写了一篇文章,其中提及了当你已经配置了软删除,却想级联删除相关模型的外键约束时会发送什么情况:
一般情况下我都会使用 MySQL 的外键约束来删除管理的记录。在 Laravel 中这很容易做到,你只需要在 Migration 文件里的某个表字段上设置一个
onDelete
函数即可神奇般地自动删除。但是,当你开启软删除后,该怎么处理呢?你只是更新了
deleted_at
字段,你的数据库没接收到 真正的 删除某条记录的命令,所以你的关联数据纹丝不动,变成了垃圾数据。
文章里他分享了解决方案,允许你通过简单地配置模型文件来达到联动软删除的目的,而不用编写一堆的初始化代码:
我的解决方案是在模型中使用事件和数组来设置联动删除,只需要两行代码,即可做到联动删除和还原删除。
使用这个包,你可以启动 SoftCascadeTrait
并配置哪些关系应该软级联删除:
use \Askedio\SoftCascade\Traits\SoftCascadeTrait;
protected $softCascade = ['profiles'];
定义关系后,你可以在模型是触发一个删除或恢复, 并且将与模型一起恢复或(软)删除相关模型:
User::first()->delete();
User::withTrashed()->first()->restore();
更多信息
准备开始,使用 composer 按照包,同时 Laravel 的自动发现特性会帮你搞定剩余部分:
composer require askedio/laravel-soft-cascade
查看 GitHub 仓库 及 Will Bowman 的文章 来获取更多信息。
本文中的所有译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时联系我们。
推荐文章: