美文网首页
ThinkPHP 5 的软删除 softDelete

ThinkPHP 5 的软删除 softDelete

作者: 喷射的熔浆 | 来源:发表于2017-08-30 03:42 被阅读0次

现在 ThinkPHP 5 的版本到了5.0.10了。从5.0.0开始,think\Model类就提供了软删除的快捷操作。
SoftDelete是一个trait,可以方便地把记录标记为删除,而实际不删除。

为表类配置软删除

软删除的原理是,表中的一个字段(field),例如 delete_time,如果删除,就把当前时间写入。每次获取的时候,如果这个字段不是NULL就跳过而已。自己实现和恨简单,不过tp5已经有了就没必要自己动手了

<?php
namespace app\tbl;

use think\Model;
use traits\model\SoftDelete;

class Follower extends Model(){
    use SoftDelete;
    protected $deleteTime = 'delete_time';
    ...
}

表中的字段delete_time需要设置为varchar类型,虽然文档中说设置成datetimetimestamp可以的,but我的总是报错1,改成varchar(20)就好了。

使用软删除

例如用户取消关注了公众号,就把ta软删除了

use app\tbl\Follower;
...
Follower::destory($openid);
...

恢复软删除

例如用户又关注了,需要恢复用户的操作权限

use think\Db;
...
Db::table($table_prefix.'follower')->where('openid', $openid)->->update(['delete_time' => ['exp', 'null']]);
...

或者,也可以

use app\tbl\Follower;
...
$user =  Follower::onlyTrashed()->where('openid', $openid);
$user->update(['delete_time' => ['exp', 'null']]);

注意:上面不能使用save(),无效

$user->save('delete_time' => NULL, ['openid'=>$openid]);

直接使用(无效)是没有用的,因为已经::get()不到了,结果就是NULL

use app\tbl\Follower;
...
$user = Follower::get($openid);
$user->delete_time = NULL;
$user->save()
...

上面使用::withTrashed()::onlyTrashed()都可以

Reference

  1. hinkPHP5.x回收softDelete过的记录

相关文章

网友评论

      本文标题:ThinkPHP 5 的软删除 softDelete

      本文链接:https://www.haomeiwen.com/subject/etkzdxtx.html