软删除

数据频繁删除操作会导致性能问题 软删除就是把数据加上删除标记 而不是真正的删除 同时也便于需要的时候进行数据的恢复。

引入SoftDelete trait
User模型按照下面的定义就可以使用软删除功能:

<?php
namespace app\index\model;
use thinkModel;
use think\model\concern\SoftDelete;
class User extends Model{
use SoftDelete;
protected $deleteTime = 'delete_time';
}

deleteTime属性用于定义软删除标记字段
软删除功能使用时间戳类型(数据表默认值为Null) 用于记录数据的删除时间

defaultSoftDelete属性来定义软删除字段的默认值

<?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();