软删除
数据频繁删除操作会导致性能问题 软删除就是把数据加上删除标记 而不是真正的删除 同时也便于需要的时候进行数据的恢复。
引入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();
尊贵的董事大人
英文标题不为空时 视为本栏投稿
需要关键字 描述 英文标题