💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
# 软删除 ## 软删除 在实际项目中,对数据频繁使用删除操作会导致性能问题,软删除的作用就是把数据加上删除标记,而不是真正的删除,同时也便于需要的时候进行数据的恢复。 要使用软删除功能,需要引入`SoftDelete` trait,例如`User`模型按照下面的定义就可以使用软删除功能: ``` <?php namespace app\index\model; use think\Model; use think\model\concern\SoftDelete; class User extends Model { use SoftDelete; protected $deleteTime = 'delete_time'; } ``` `deleteTime`属性用于定义你的软删除标记字段,`ThinkPHP`的软删除功能使用时间戳类型(数据表默认值为`Null`),用于记录数据的删除时间。 > `V5.1.9+`版本开始,可以支持`defaultSoftDelete`属性来定义软删除字段的默认值,在此之前的版本,软删除字段的默认值必须为`null`。 ``` <?php namespace app\index\model; use think\Model; use think\model\concern\SoftDelete; class User extends Model { use SoftDelete; protected $deleteTime = 'delete_time'; protected $defaultSoftDelete = 0; } ``` > 可以用类型转换指定软删除字段的类型,建议数据表的所有时间字段统一一种类型。 定义好模型后,我们就可以使用: ``` // 软删除 User::destroy(1); // 真实删除 User::destroy(1,true); $user = User::get(1); // 软删除 $user->delete(); // 真实删除 $user->delete(true); ``` 默认情况下查询的数据不包含软删除数据,如果需要包含软删除的数据,可以使用下面的方式查询: ``` User::withTrashed()->find(); User::withTrashed()->select(); ``` 如果仅仅需要查询软删除的数据,可以使用: ``` User::onlyTrashed()->find(); User::onlyTrashed()->select(); ``` 恢复被软删除的数据 ``` $user = User::onlyTrashed()->find(1); $user->restore(); ``` > 软删除仅对模型的删除方法有效,如果直接使用数据库的删除方法则无效,例如下面的方式无效(将不会执行任何操作)。 ``` $user = new User; $user->where('id',1)->delete(); ```