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('delete
d_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 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)
如何彻底卸载建站之星软件?
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
如何安全更换建站之星模板并保留数据?
油猴 教程,油猴搜脚本为什么会网页无法显示?

