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. 获取session中存储的所有值的方法

    记录一个获取系统中session存储的对象都有哪些的方法 HttpSession session = request.getSession(); for ( Enumeration e = sessi ...

  2. 一个Web报表项目的性能分析和优化实践(七):性能监测工具JavaMelody

    简介 JavaMelody 能够监测Java或Java EE应用程序服务器,并以图表的方式显示:Java内存和Java CPU使用情况,用户Session数量,JDBC连接数,和http请求.sql请 ...

  3. double 失真例子

    public static void main(String[] args) {  // TODO Auto-generated method stub  double ab=821.20;  dou ...

  4. MyBatis学习总结(11)——MyBatis动态Sql语句

    MyBatis中对数据库的操作,有时要带一些条件,因此动态SQL语句非常有必要,下面就主要来讲讲几个常用的动态SQL语句的语法 MyBatis中用于实现动态SQL的元素主要有: if choose(w ...

  5. HUD——T 3836 Equivalent Sets

    http://acm.hdu.edu.cn/showproblem.php?pid=3836 Time Limit: 12000/4000 MS (Java/Others)    Memory Lim ...

  6. C++里面virtual函数及虚表大小

    实验了下面的函数: #include <vector> #include <iostream> using namespace std; class A { public: v ...

  7. Android实战简易教程-第二十五枪(基于Baas的数据表查询下拉刷新和上拉载入实现!)

    上一节我们实现了数据表的载入,可是,当数据表数据非常多时.我们就要考虑数据的分页.这里我们选用了PullToRefreshListView控件,先看一下该控件的说明: 效果图:            ...

  8. php课程 13-43 mysql的数据结构是什么

    php课程 13-43 mysql的数据结构是什么 一.总结 一句话总结:cs结构,客户端,服务器 1.常用的比较出名的数据库有哪些? SQL数据库(关系型):1.收费:DB2SqlserverOra ...

  9. 多类别分类问题由 confusion matrix 到分类准确率(accuracy)的计算

    conf_mat = confusionmat(y_true, y_pred); % 首先根据数据集上的真实 label 值,和训练算法给出的预测 label 值, % 计算 confusion ma ...

  10. 10.查看npm安装信息和版本号

    转自:http://www.runoob.com/nodejs/nodejs-express-framework.html 你可以使用以下命令来查看所有全局安装的模块: $ npm list -g ├ ...