ThinkPHP 6通过SoftDelete实现软删除,需模型继承Model并引入SoftDelete trait,设置$deleteTime字段;数据库添加delete_time字段存储删除时间;调用delete()标记删除,自动更新delete_time;查询时默认过滤已删除数据,可用withTrashed()或onlyTrashed()包含或仅查删除数据;restore()方法可恢复已删除记录。

ThinkPHP 的软删除功能主要用于标记数据为“已删除”状态,而不是真正从数据库中物理删除记录。这种方式可以保留历史数据,便于后续恢复或审计。ThinkPHP 6.0 版本原生支持软删除功能,以下是具体实现方式。
启用软删除
要在模型中使用软删除,需让模型类继承 thinkModel 并使用 thinkmodelconcernSoftDelete trait。
注意:ThinkPHP 6 默认未加载 SoftDelete,需要手动引入并配置。
示例代码:
namespace appmodel;use thinkModel;use thinkmodelconcernSoftDelete;
class User extends Model{use SoftDelete;
// 定义软删除字段,默认为 delete_timeprotected $deleteTime = 'delete_time';}
立即学习“PHP免费学习笔记(深入)”;
数据库字段设置
软删除依赖一个时间字段来记录删除时间。通常这个字段名为 delete_time,类型为 DATETIME 或 TIMESTAMP,允许为空。
建表时添加该字段:
-- 示例 SQLCREATE TABLE `user` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `create_time` datetime DEFAULT NULL, `update_time` datetime DEFAULT NULL, `delete_time` datetime DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;执行软删除操作
调用模型的 delete() 方法时,如果启用了软删除,系统会自动更新 delete_time 字段,而不是删除记录。
示例:
$user = User::find(1);if ($user) { $user->delete(); // 软删除,update delete_time = NOW()}此时数据库中该记录依然存在,只是 delete_time 被写入当前时间。
查询时自动过滤已删除数据
默认情况下,使用模型查询时会自动排除已软删除的记录(即 delete_time 不为 NULL 的数据)。
例如:
User::select();这条语句只会返回 delete_time 为 NULL 的记录。
如需查询包含已删除的数据,可使用:
User::withTrashed()->select();只查已被软删除的数据:
User::onlyTrashed()->select();恢复已软删除的数据
可以通过调用 restore() 方法将软删除的记录恢复。
示例:
$user = User::onlyTrashed()->find(1);if ($user) { $user->restore(); // 将 delete_time 设为 NULL}恢复后,该记录重新参与正常查询。
基本上就这些。只要模型正确使用 SoftDelete trait,数据库有 delete_time 字段,框架就会自动处理软删除逻辑。不复杂但容易忽略字段和命名的一致性。
以上就是thinkphp软删除(softDelete)功能如何实现的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/144294.html
微信扫一扫
支付宝扫一扫