laravel怎么实现软删除和数据恢复_laravel软删除与数据恢复方法

发布时间 - 2025-10-14 00:00:00    点击率:
答案:Laravel通过SoftDeletes trait实现软删除,需添加deleted_at字段,删除时记录时间,恢复时清空该字段,可查询已删数据并支持永久删除。

如果您在使用 Laravel 构建应用时,希望删除数据时不真正从数据库移除记录,而是标记为已删除状态,并能在后续恢复这些数据,可以利用 Laravel 提供的软删除功能。以下是实现软删除及数据恢复的具体步骤:

本文运行环境:MacBook Pro,macOS Sonoma

一、启用模型的软删除功能

要实现软删除,需要在目标模型中引入 SoftDeletes trait,并在数据库表中添加 deleted_at 字段。该字段用于存储记录被删除的时间。

1、在对应的 Eloquent 模型文件中引入 SoftDeletes trait:

use Illuminate\Database\Eloquent\SoftDeletes;

2、在模型类中使用该 trait:

class Article extends Model { use SoftDeletes; }

二、创建迁移文件并添加 deleted_at 字段

deleted_at 字段是软删除机制的核心,Laravel 通过检测该字段是否为 null 来判断记录是否已被“删除”。

1、生成迁移文件:

php artisan make:migration add_deleted_at_to_articles_table --table=articles

2、在 up 方法中添加 timestamp 类型的 deleted_at 字段:

$table->timestamp('deleted_at')->nullable();

3、运行迁移命令以更新数据库结构:

php artisan migrate

三、执行软删除操作

当模型启用了软删除后,调用 delete() 方法不会真正从数据库中删除记录,而是将 deleted_at 字段设置为当前时间。

1、获取一条记录并执行删除:

$article = Article::find(1); $article->delete();

2、验证数据是否已被软删除:

dd($article->fresh()->deleted_at); // 输出删除时间

四、查询包含或排除已软删除的数据

Laravel 默认查询只会返回未删除的记录,但可以通过特定方法访问已被软删除的数据。

1、获取所有未删除的记录(默认行为):

$activeArticles = Article::all();

2、获取已被软删除的记录:

$trashedArticles = Article::onlyTrashed()->get();

3、获取包括已删除和未删除的所有记录:

$allArticles = Article::withTrashed()->get();

五、恢复已软删除的数据

恢复操作会将 deleted_at 字段清空,使记录重新变为可用状态。

1、恢复单条已删除记录:

$article = Article::withTrashed()->find(1); $article->restore();

2、批量恢复符合条件的已删除记录:

Article::onlyTrashed()->where('category_id', 2)->restore();

六、永久删除数据

若确认某些数据不再需要,可绕过软删除机制直接从数据库彻底移除。

1、对已软删除的记录执行强制删除:

$article = Article::withTrashed()->find(1); $article->forceDelete();

2、批量永久删除所有已软删除的记录:

Article::onlyTrashed()->forceDelete();


# laravel  # php  # go  # macbook  # mac  # ai  # macos  # 数据恢复  # cos  # NULL  # timestamp  # class  # Nullable  # delete  # table  # database  # 数据库  # 已被  # 移除  # 清空  # 运行环境  # 并在  # 只会  # 可以通过  # 您在  # 设置为  # 并能 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何为不同团队 ID 动态生成多个独立按钮  HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  如何快速辨别茅台真假?关键步骤解析  b2c电商网站制作流程,b2c水平综合的电商平台?  免费视频制作网站,更新又快又好的免费电影网站?  php json中文编码为null的解决办法  Laravel如何实现文件上传和存储?(本地与S3配置)  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  进行网站优化必须要坚持的四大原则  如何在云虚拟主机上快速搭建个人网站?  ,交易猫的商品怎么发布到网站上去?  Laravel如何实现一对一模型关联?(Eloquent示例)  七夕网站制作视频,七夕大促活动怎么报名?  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  免费网站制作appp,免费制作app哪个平台好?  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  EditPlus中的正则表达式 实战(4)  如何快速搭建二级域名独立网站?  linux写shell需要注意的问题(必看)  如何在 Pandas 中基于一列条件计算另一列的分组均值  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  怎样使用JSON进行数据交换_它有什么限制  Laravel distinct去重查询_Laravel Eloquent去重方法  5种Android数据存储方式汇总  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用  Laravel如何与Pusher实现实时通信?(WebSocket示例)  Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康  利用 Google AI 进行 YouTube 视频 SEO 描述优化  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  Laravel怎么生成URL_Laravel路由命名与URL生成函数详解  如何选择可靠的免备案建站服务器?  网站制作免费,什么网站能看正片电影?  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  如何快速搭建高效服务器建站系统?  如何在建站之星网店版论坛获取技术支持?  php 三元运算符实例详细介绍  如何在建站宝盒中设置产品搜索功能?  如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)  如何彻底卸载建站之星软件?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  如何安全更换建站之星模板并保留数据?  油猴 教程,油猴搜脚本为什么会网页无法显示?