thinkphp自动完成、软删除 和时间戳

一、总结

自动完成:没有手动赋值的情况下进行手动处理

软删除:实现假删除,可以进行恢复

时间戳:系统支持自动写入创建和更新的时间戳字段

二、thinkphp自动完成、软删除 和时间戳

1、自动完成

1、修改器和自动完成区别

修改器:数据赋值的时候自动进行转换处理

自动完成:没有手动赋值的情况下进行手动处理

2、自动完成

// 增加和修改操作都会执行

protected $auto=[];

// 创建数据执行

protected $insert=['create_time'];

// 修改数据执行

protected $update=['update_time'];

2、时间戳

1、系统支持自动写入创建和更新的时间戳字段

1) 在配置文件中设置

// 自动写入时间戳字段

'auto_timestamp'  => true,

2) 在数据模型中设置

// 设置自动写入时间戳

protected $autoWriteTimestamp=true;

2、可以设置字段默认值

// 增加时间的字段

protected $createTime='create_times';

// 更新时间的字段

protected $updateTime='update_times';

3、取消更新时间戳设置

protected $updateTime=false;

3、软删除

1、作用:

实现假删除,可以进行恢复

2、实现

<?php

// 声明命名空间

namespace app\index\model;

// 导入系统的数据模型

use think\Model;

// 配合软删除

use traits\model\SoftDelete;

// 声明user模型

class User extends Model{

// 使用软删除

use SoftDelete;

// 设置删除的时间戳

protected $deleteTime="delete_times";

}

3、控制器

1、删除数据

$res=User::destroy(15);

2、获取数据

$res=User::get(15);

// 软删除 数据库数据存在,但是get获取不到

3、直接删除数据

$res=User::destroy(14,true);

$user=new User();

$res=$user->where("id",'5')->delete();

4、读取所有数据包含软删除数据

$res=User::withTrashed()->find(15);

$res=User::withTrashed()->select();

5、仅仅读取软删除数据

$res=User::onlyTrashed()->select();

$res=User::onlyTrashed()->find(1);

thinkphp自动完成、软删除 和时间戳的更多相关文章

  1. laravel框架总结(九) -- 软删除

    当模型被软删除时,它们并不会真的从数据库中被移除.而是会在模型上设置一个 deleted_at 属性并将其添加到数据库.如果对应模型被软删除,则deleted_at字段的值为删除时间,否则该值为空. ...

  2. ThinkPHP 自动验证与自动填充无效可能的原因(转)

    自动验证与自动填充是在使用ThinkPHP时经常用到的功能,但偶尔会遇到自动验证与自动填充无效的情况,本文就ThinkPHP 自动验证与自动填充无效可能的原因做一些分析. create() Think ...

  3. ThinkPHP 自动验证与自动填充无效可能的原因

    原文链接:http://www.5idev.com/p-thinkphp_validate_auto_Invalid.shtml 自动验证与自动填充是在使用ThinkPHP时经常用到的功能,但偶尔会遇 ...

  4. Yii2 软删除

    什么是软删除 后台操作,删除一条记录,不希望真正的从数据库中删除,用个字段标记一下.比如delete_at.默认0.当执行删除操作,更新delete_at为当前时间戳 这样列表显示的时候只查询dele ...

  5. 实现HBase增量入库(HBase删除自定义时间戳行数据)

    目录 1. 背景描述 2. 问题描述 3. 解决方案 1. 背景描述 目前在做音乐推荐项目,前期做排序模型优化,任务是使用模型对用户的历史音乐进行排序,有6800多万个用户,约40G的用户数据,使用H ...

  6. Laravel5.1 模型 --软删除

    软删除是比较实用的一种删除手段,比如说 你有一本账 有一笔记录你觉得不对给删了 过了几天发现不应该删除,这时候软删除的目的就实现了 你可以找到已经被删除的数据进行操作 可以是还原也可以是真正的删除. ...

  7. laravel5.2总结--软删除

    当模型被软删除时,它们并不会真的从数据库中被移除.而是会在模型上设置一个 deleted_at 属性并将其添加到数据库.如果对应模型被软删除,则deleted_at字段的值为删除时间,否则该值为空. ...

  8. ef core SoftDelete Multi-tenancy 软删除、多租户实现 Global Query Filters

    ef core提供了Global Query Filters特性来实现多租户与软删除,收集了一些实现方法. 最简单的例子时微软官方的特性解释. https://docs.microsoft.com/e ...

  9. xorm-删除和软删除实例

    删除数据Delete方法,参数为struct的指针并且成为查询条件.注意:当删除时,如果user中包含有bool,float64或者float32类型,有可能会使删除失败 package main i ...

随机推荐

  1. javafx Hanoi

    Netbean  java8    source code  :http://files.cnblogs.com/files/rojas/HNT.zip screenshot: 1  model /* ...

  2. javafx clipboard

    public class EffectTest extends Application { public static void main(String[] args) { launch(args); ...

  3. Shiro + SSM(框架) + Freemarker(jsp)

    Shiro + SSM(框架) + Freemarker(jsp)讲解的权限控制Demo,还不赶快去下载? 我们知道Ajax不能做页面redirect和forward跳转,所以Ajax请求假如没登录, ...

  4. 【Django】缓存

    由于Django是动态网站,所以每次请求都会去数据库中进行响应的操作. 当程序访问量大时,耗时必然会更加明显,最简单的解决方案就是使用缓存. Django中的缓存: ==即将某一个view的返回值保存 ...

  5. 【Python】【Head First Python】【chapter1】2 - sys.stdout 和 print 的区别

    sys.stdout 和 print 的区别 首先,通过 help(print) 得到print内建函数的参数 Help on built-in function print in module bu ...

  6. Nim游戏算法实现

  7. Jquery学习总结(1)——Jquery常用代码片段汇总

    1. 禁止右键点击 ? 1 2 3 4 5 $(document).ready(function(){     $(document).bind("contextmenu",fun ...

  8. vue-cli 和webpack

    https://note.youdao.com/share/?id=d1851db9f0fe0a691798fac823849564&type=notebook#/C045BC3E7DC144 ...

  9. activity 接回返回值

    activity 接回返回值 今天做订单列表显示 点击某一项显示订单详细信息,在详细activity中用户可以选择取消订单(未支付的状态下)当用户取消订单后订单列表也要改变状态,原来最初做法是所加载绑 ...

  10. BZOJ5137: [Usaco2017 Dec]Standing Out from the Herd(广义后缀自动机,Parent树)

    Description Just like humans, cows often appreciate feeling they are unique in some way. Since Farme ...