0

0

Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-12-27 15:00:39

|

870人浏览过

|

来源于php中文网

原创

加了 SoftDeletes trait 还查不到 deleted_at 字段是因为该 trait 仅启用软删除逻辑,不自动添加数据库字段;必须手动创建迁移并使用 $table->softDeletes() 添加 deleted_at 字段。

laravel怎么实现软删除softdeletes_laravel模型回收站功能与数据恢复【步骤】

为什么加了 SoftDeletes trait 还查不到 deleted_at 字段

因为 SoftDeletes 只是启用软删除逻辑,不会自动在数据库中添加 deleted_at 字段。必须手动迁移添加:

  • 运行 php artisan make:migration add_deleted_at_to_users_table
  • 在迁移文件的 up() 方法里写:
    public function up(Blueprint $table)
    {
        $table->softDeletes();
    }
  • 执行 php artisan migrate

注意:如果表已存在且有数据,softDeletes() 会添加可为 NULL 的 deleted_at 字段;但不会修改已有记录的该字段值,所以历史数据默认不被视为“已删除”。

调用 delete() 后数据没消失但 where 查询查不到

这是软删除的预期行为:调用 $user->delete() 会把 deleted_at 设为当前时间戳,而非真正删掉行。Laravel 默认的 Eloquent 查询会自动加上 WHERE deleted_at IS NULL 条件。

  • 想查出所有记录(含已软删除的):用 User::withTrashed()->get()
  • 只查已软删除的:用 User::onlyTrashed()->get()
  • 恢复单条:用 $user->restore()(会清空 deleted_at
  • 强制物理删除:用 $user->forceDelete()

注意:关联查询(如 $user->posts)默认也不会加载已软删除的关联记录,除非对应模型也用了 SoftDeletes 并显式调用 withTrashed()

restore() 不生效或报错 “Call to undefined method”

常见原因有两个:

Litero
Litero

AI co-writer for students

下载
  • 模型没 use Illuminate\Database\Eloquent\SoftDeletes trait,只加了迁移字段没用
  • 调用方式错误:比如对集合批量调用 restore() 时没用 each(),直接写 $users->restore() 会失败

正确批量恢复示例:

$users = User::onlyTrashed()->where('created_at', '<', now()->subWeek())->get();
$users->each->restore(); // 或 $users->each(function ($u) { $u->restore(); });

另外,如果模型启用了全局作用域(如多租户 scope),要确认 restore() 是否被拦截 —— 它不触发 creating/updating 等事件,但会触发 restoringrestored 事件。

软删除后关联数据怎么处理:级联 or 保留

Laravel 不自动处理软删除的关联级联。比如 User 软删除,它的 Post 记录默认仍可查(除非 Post 自己也用了 SoftDeletes)。

  • 想让关联也软删除:需手动在模型事件里实现,例如监听 deleting 事件,然后调用 $this->posts()->update(['deleted_at' => now()])
  • 想物理删除关联:监听 forceDeleted 事件,再执行 $this->posts()->forceDelete()
  • 避免误恢复时带出脏关联:恢复主模型前,先检查并同步恢复关联模型(需自行编码逻辑)

没有银弹方案。是否级联、怎么级联,得看业务——回收站功能通常要求“主模型恢复时,其软删除的子数据也一并恢复”,这必须自己控制,Eloquent 不代劳。

相关文章

数据恢复工具app
数据恢复工具app

手机里的数据丢失了怎么办?聊天记录不小心删掉了怎么办?不用担心,这里为大家提供了数据恢复工具app下载,安全正规,有需要的小伙伴保存下载,就轻松恢复数据啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1752

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1167

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1061

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1396

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1228

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1439

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

27

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 7.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号