thinkphp软删除(softDelete)功能如何实现

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

thinkphp软删除(softDelete)功能如何实现

ThinkPHP 的软删除功能主要用于标记数据为“已删除”状态,而不是真正从数据库中物理删除记录。这种方式可以保留历史数据,便于后续恢复或审计。ThinkPHP 6.0 版本原生支持软删除功能,以下是具体实现方式。

启用软删除

要在模型中使用软删除,需让模型类继承 thinkModel 并使用 thinkmodelconcernSoftDelete trait。

注意:ThinkPHP 6 默认未加载 SoftDelete,需要手动引入并配置。

示例代码:

 namespace appmodel; <p>use thinkModel; use thinkmodelconcernSoftDelete;</p><p>class User extends Model { use SoftDelete;</p><pre class='brush:php;toolbar:false;'>// 定义软删除字段,默认为 delete_time protected $deleteTime = 'delete_time';

}

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

数据库字段设置

软删除依赖一个时间字段来记录删除时间。通常这个字段名为 delete_time,类型为 DATETIME 或 TIMESTAMP,允许为空。

建表时添加该字段:

 -- 示例 SQL CREATE 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 的数据)。

例如:

thinkphp软删除(softDelete)功能如何实现

SpeakingPass-打造你的专属雅思口语语料

使用chatGPT帮你快速备考雅思口语,提升分数

thinkphp软删除(softDelete)功能如何实现25

查看详情 thinkphp软删除(softDelete)功能如何实现

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 php app ai thinkphp NULL timestamp 继承 delete 数据库

大家都在看:

thinkphp php app ai thinkphp NULL timestamp 继承 delete 数据库

app
上一篇
下一篇