0

0

ThinkPHP6模型软删除功能怎么开启和使用_软删除实现【教程】

蓮花仙者

蓮花仙者

发布时间:2026-03-18 08:16:31

|

884人浏览过

|

来源于php中文网

原创

必须在模型类中显式引入think\model\concern\SoftDelete trait并声明$deleteTime,否则软删除方法报错;destroy()为静态批量软删,delete()为实例单条软删,where()->delete()会绕过软删除直接硬删。

thinkphp6模型软删除功能怎么开启和使用_软删除实现【教程】

模型类里怎么正确引入 SoftDelete Trait

软删除不是开个配置就行,必须在模型类里显式引入 SoftDelete 这个 trait,否则所有软删除方法(比如 onlyTrashed()restore())都会报错“方法不存在”。

常见错误是只写 use SoftDelete; 却没加命名空间——ThinkPHP6 的路径是 think\model\concern\SoftDelete,不是旧版的 traits\model\SoftDelete

  • 正确写法:use think\model\concern\SoftDelete; + use SoftDelete;
  • protected $deleteTime = 'delete_time'; 必须声明,字段名要和数据库一致(默认是 delete_time,不是 deleted_at
  • 如果数据库字段类型是 int(时间戳),别忘了设 protected $type = ['delete_time' => 'integer'];,否则 NULL 写不进 int 字段会静默失败

destroy() 和 delete() 的行为差异与选法

destroy() 是静态方法,适合批量或条件删除;delete() 是实例方法,必须先查出来再删。两者都走软删除逻辑,但触发时机和参数支持完全不同。

容易踩坑的是:用 where()->delete()(注意不是模型的 delete(),而是查询构造器的)——它绕过模型事件和软删除机制,直接硬删,数据彻底消失。

立即学习PHP免费学习笔记(深入)”;

SongAI
SongAI

免费AI歌曲和音乐生成平台,支持文字生成歌曲、AI歌词创作、AI翻唱等功能

下载
  • 单条软删:Users::find(123)->delete();Users::destroy(123);
  • 批量软删:Users::destroy([1, 2, 3]);Users::destroy(['status' => 0]);
  • 带条件软删:Users::destroy(function($query) { $query->where('created_time', '
  • 绝对避免:Users::where('id', 123)->delete();(这是硬删)

查不到被删数据?检查是否漏了 onlyTrashed() 和 withTrashed()

开启软删除后,select()find() 等所有查询默认自动过滤掉 delete_time IS NOT NULL 的记录。这不是 bug,是设计行为——但新手常以为“删了却还查得到”或“明明删了却查不到”,其实是没搞清查询范围。

  • 查正常数据(默认行为):Users::where('name', '张三')->select();
  • 查仅软删除数据:Users::onlyTrashed()->where('id', 123)->find();
  • 查全部(含已软删):Users::withTrashed()->where('id', 123)->find();
  • 恢复数据:Users::onlyTrashed()->find(123)->restore();(注意:必须先 onlyTrashed() 才能拿到软删记录)

真正删掉一条软删除记录:force() 不是万能钥匙

force() 是个链式方法,它本身不执行删除,只是告诉后续的 delete()destroy() “这次来真的”。单独调用 $user->force() 没效果,必须接上删除动作。

另一个坑是:用 destroy() 硬删时,第二个参数 true 表示 force,但这个 true 只对主键数组有效,对闭包或条件数组无效——那种情况必须先查再 force()->delete()

  • 正确硬删单条:$user = Users::onlyTrashed()->find(123); $user->force()->delete();
  • 正确硬删主键:Users::destroy(123, true);Users::destroy([123, 456], true);
  • 错误写法:Users::destroy(function($q) { $q->where('xxx'); }, true); —— 这里的 true 被忽略

软删除字段一旦被设为非 NULL,就再也无法用普通查询命中,除非你明确切换作用域。这点在写后台回收站或审计日志时,很容易漏掉 withTrashed() 导致数据“凭空消失”。

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

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

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

387

2024.04.10

thinkphp性能怎么样
thinkphp性能怎么样

thinkphp 是一款高性能的 php 框架,具备缓存机制、代码优化、并行处理和数据库优化等优势。官方性能测试显示,它每秒可处理超过 10,000 个请求,实际应用中被广泛用于京东商城、携程网等大型网站和企业系统。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

362

2024.04.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

256

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1154

2024.03.01

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1091

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

619

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

355

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

235

2025.08.29

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

17

2026.03.17

热门下载

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

精品课程

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

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