ThinkPHP 5 的软删除 softDelete
web ThinkPHP5.1 2019-01-08 3300 0
关于本站

“最难不过坚持”

本人承接扒站仿站,php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

7440377 2655 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (254)
Mysql (58)
DedeCms (33)
jQuery (67)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)
现在 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类型,虽然文档中说设置成datetime和timestamp可以的,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()都可以

版权声明:本篇文章来源于网络。 来源链接

相关推荐
Non-static method think\Config::get() should not be called statically
ThinkPHP5.1 | 2018-12-29 10949
原来是这样use think\Config; 改成这样use think\facade\Config; 下面是官方手册的解释 配置获取 要使用Config类,首先需要在你的类文件中引入 use think\facade\Config; 或者(因为系统做了类库别名,其实就是调用think\facade\Config) u...
thinkPHP5 order多条件排序
ThinkPHP5.1 | 2017-10-24 10809
总结如下: //单一条件排序 $user = $this->where(['parentId'=>0)->field('userId,userName,userSort,isShow')->order('userSort', 'asc')->select(); //多个条件排序,可以多加一个order...
评论:0条
评论加载中...
发表评论