[扩展推荐] Laravel 关联模型的软删除联动解决方案

翻译 Summer ⋅ 于 2周前 ⋅ 最后回复由 linkphper 1天前 ⋅ 697 阅读 ⋅ 原文地址
这是一篇社区协同翻译的文章,已完成翻译,更多信息请点击 协同翻译介绍

file

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

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

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

BradStev 翻译于 2周前

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

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

文章里他分享了解决方案,允许你通过简单地配置模型文件来达到联动软删除的目的,而不用编写一堆的初始化代码:

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

Summer 翻译于 2周前

使用这个包,你可以启动 SoftCascadeTrait 并配置哪些关系应该软级联删除:

use \Askedio\SoftCascade\Traits\SoftCascadeTrait;

protected $softCascade = ['profiles'];

定义关系后,你可以在模型是触发一个删除或恢复, 并且将与模型一起恢复或(软)删除相关模型:

User::first()->delete();
User::withTrashed()->first()->restore();
BradStev 翻译于 2周前

更多信息

准备开始,使用 composer 按照包,同时 Laravel 的自动发现特性会帮你搞定剩余部分:

composer require askedio/laravel-soft-cascade

查看 GitHub 仓库 及 Will Bowman 的文章 来获取更多信息。

BradStev 翻译于 2周前

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

译文地址:https://laravel-china.org/topics/10965/s...


本文中的所有译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时联系我们。

本帖已被设为精华帖!

文章译者

回复数量: 1
  • linkphper 一只专注于PHP的程序猿!
    2周前

    这个包不错,不用担心数据不完整导致的问题了 :blush:

暂无评论~~

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