6自动时间戳
未知
2021-07-04 11:23:52
0

系统支持自动写入创建和更新的时间戳字段(默认关闭),有两种方式配置支持。

第一种方式是全局开启,在数据库配置文件中进行设置:

// 开启自动写入时间戳字段
'auto_timestamp' => true,
复制

第二种是在需要的模型类里面单独开启:

<?php
namespace app\model;

use think\Model;

class User extends Model
{
    protected $autoWriteTimestamp = true;
}
复制

又或者首先在数据库配置文件中全局开启,然后在个别不需要使用自动时间戳写入的模型类中单独关闭:

<?php
namespace app\model;

use think\Model;

class User extends Model
{
    protected $autoWriteTimestamp = false;
}
复制

一旦配置开启的话,会自动写入create_timeupdate_time两个字段的值,默认为整型(int),如果你的时间字段不是int类型的话,可以直接使用:

// 开启自动写入时间戳字段
'auto_timestamp' => 'datetime',
复制

或者

<?php
namespace app\model;

use think\Model;

class User extends Model
{
    protected $autoWriteTimestamp = 'datetime';
}
复制

默认的创建时间字段为create_time,更新时间字段为update_time,支持的字段类型包括timestamp/datetime/int

写入数据的时候,系统会自动写入create_timeupdate_time字段,而不需要定义修改器,例如:

$user = new User();
$user->name = 'thinkphp';
$user->save();
echo $user->create_time; // 输出类似 2016-10-12 14:20:10
echo $user->update_time; // 输出类似 2016-10-12 14:20:10
复制

时间字段的自动写入仅针对模型的写入方法,如果使用数据库的更新或者写入方法则无效。

时间字段输出的时候会自动进行格式转换,如果不希望自动格式化输出,可以把数据库配置文件的 datetime_format 参数值改为false

datetime_format参数支持设置为一个时间类名,这样便于你进行更多的时间处理,例如:

// 设置时间字段的格式化类
'datetime_format' => '\org\util\DateTime',
复制

该类应该包含一个__toString方法定义以确保能正常写入数据库。

如果你的数据表字段不是默认值的话,可以按照下面的方式定义:

<?php
namespace app\model;

use think\Model;

class User extends Model 
{
    // 定义时间戳字段名
    protected $createTime = 'create_at';
    protected $updateTime = 'update_at';
}
复制

下面是修改字段后的输出代码:

$user = new User();
$user->name = 'thinkphp';
$user->save();
echo $user->create_at; // 输出类似 2016-10-12 14:20:10
echo $user->update_at; // 输出类似 2016-10-12 14:20:10
复制

如果你只需要使用create_time字段而不需要自动写入update_time,则可以单独关闭某个字段,例如:

namespace app\model;

use think\Model;

class User extends Model 
{
    // 关闭自动写入update_time字段
    protected $updateTime = false;
}
复制

支持动态关闭时间戳写入功能,例如你希望更新阅读数的时候不修改更新时间,可以使用isAutoWriteTimestamp方法:

$user = User::find(1);
$user->read +=1;
$user->isAutoWriteTimestamp(false)->save();
复制

上一篇:6数据集

下一篇:6只读字段

相关内容

XXX研讨会
XXX研讨会集结了专家学者和业界精英,聚焦XXX领域热点话题,通过...
2025-02-10 08:00:40
《哪吒2》中国影史第一个8...
《哪吒2》中国影史首个80亿大作,以卓越艺术与技术成就铸就辉煌,再...
2025-02-10 07:00:43
国产剧终于有不靠男主救的女...
国产剧新趋势:女主角不再依赖男主救援,展现独立与坚强。打破传统模式...
2025-02-10 05:46:37
2024年全国结婚登记61...
2024年全国结婚登记610.6万对显示现代婚姻市场稳定趋势,反映...
2025-02-10 05:00:38
比亚迪第二代秦PLUS智驾...
比亚迪第二代秦PLUS智驾版明晚上市,以卓越的智能驾驶技术和外观设...
2025-02-10 04:46:50
触发器与事件处理程序的比较
触发器与事件处理程序是用于处理特定事件的两种机制。触发器是数据库对...
2025-02-09 12:23:36

热门资讯

tp6开发规范 命名规范 请理解并尽量遵循以下命名规范,可以减少在开发过程中出现不必要的错误。 ThinkPHP6....
6高级查询 快捷查询 快捷查询方式是 一种多字段相同查询条件 的简化写法,可以进一步简化查询条件的写法,在多个字...
tp6多应用提示控制器不存在:... 第一个情况是没有使用composer安装扩展。 如果要使用多应用模式, 你需要win+r,cmd指针...
6配置 配置目录 单应用模式 对于单应用模式来说,配置文件和目录很简单,根目录下的 config 目录下面就...
6异常处理 和PHP默认的异常处理不同,ThinkPHP抛出的不是单纯的错误信息,而是一个人性化的错误页面。 异...
6swoole 本篇内容主要讲述了最新的 think-swoole 扩展的使用。目前仅支持Linux环境或者MacO...
6助手函数 助手函数 系统为一些常用的操作方法封装了助手函数,便于使用,包含如下: 助手函数 描述 abort ...
6查询表达式 查询表达式 查询表达式支持大部分的SQL查询语法,也是 ThinkPHP 查询语言的精髓,查询表达式...
6路由参数 路由参数 路由分组及规则定义支持指定路由参数,这些参数主要完成路由匹配检测以及后续行为。 路由参数可...
6查询 模型查询和数据库查询方法的区别主要在于,模型中的查询的数据在获取的时候会经过获取器的处理,以及更加对...