Laravel 关联模型的软删除联动解决方案

一般情况下我都会使用 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 的自动加载特性会帮你搞定剩余部分:

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

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

    User::first()->delete();
    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

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容