zoukankan      html  css  js  c++  java
  • 软删除

    软删除

    版本 调整功能
    5.0.2 deleteTime 属性改为非静态定义

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

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

    namespace appindexmodel;
    
    use thinkModel;
    use traitsmodelSoftDelete;
    
    class User extends Model
    {
        use SoftDelete;
        protected $deleteTime = 'delete_time';
    }

    5.0.2版本之前deleteTime属性必须使用static定义。

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

    可以用类型转换指定软删除字段的类型,建议数据表的所有时间字段统一一种类型。

    定义好模型后,我们就可以使用:

    // 软删除
    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();
  • 相关阅读:
    sql sever 数据字典语法
    端口使用情况
    koa中间件说明
    FLIP动画思想
    跨域下载文件显示文件名
    post方法打开新页面并提交参数
    常用快捷键
    cnpm与npm安装的包不一样
    chrome devTools变量不提示,断点点击去不掉问题
    未修改的模块失效排查方法
  • 原文地址:https://www.cnblogs.com/q1104460935/p/6916135.html
Copyright © 2011-2022 走看看