Yii2 自动更新时间created_at updated_at

创建model之后,新建一条记录,结果设计的表中created_at 字段 updated_at 字段 都是datetime 类型的,却不能自动插入当前时间。查看了资料,解决如下:

1、在class CrmBusiness extends \yii\db\ActiveRecord {}中 引入use  yii\behaviors\TimestampBehavior;use yii\db\Expression;

2、覆盖父类的behaviors 方法

/**
* @inheritdoc
*/
 public function behaviors()
  {
     return [
          [
              ‘class‘ => TimestampBehavior::className(),
              ‘createdAtAttribute‘ => ‘created_at‘,// 自己根据数据库字段修改
              ‘updatedAtAttribute‘ => ‘updated_at‘, // 自己根据数据库字段修改, // 自己根据数据库字段修改
              //‘value‘   => new Expression(‘NOW()‘),
              ‘value‘   => function(){return date(‘Y-m-d H:i:s‘,time());},
          ],
      ];
 }

3、value的值需要注意:第一种方法 引入use yii\db\Expression;‘value‘   => new Expression(‘NOW()‘),第二种方法:不需要引入use yii\db\Expression;‘value‘   => function(){return date(‘Y-m-d H:i:s‘,time());},

4、问题虽然解决,但是为什么 新建数据却没有自动插入时间的原因却没有发现..............

时间: 2024-07-30 04:01:07

Yii2 自动更新时间created_at updated_at的相关文章

自动更新时间死循环脚本

1 #!/bin/sh 2 #Author:nulige 3 # qqinfo:1034611705 4 # Date: 2015-6-8 5 #实现功能:自动更新时间死循环脚本 6 7 while true 8 do 9 uptime 10 sleep 1 11 done [[email protected] script]# date2016年 04月 15日 星期五 11:54:45 CST [[email protected] script]# ll总用量 16-rw-r--r--. 1

linux系统初始化--​配置ntp自动更新时间

配置ntp自动更新时间 安装ntpdate程序 Shell># yum –y install ntpdate 使用crontab将系统设定为每天0:00与NTP服务器同步时间 Shell># crontab –e 0   0  *  *  *  ntpdate   your_ntp_server_domain_name   or  your_ntp_server_ip_addr 保存退出, 为了我们步骤继续下去,我们执行一次同步 Shell># ntpdate ntp.jn.idc 如果

android4.4中自动更新时间机制

名词解释: NITZ:NITZ(Network Identity and Time Zone)或网络标识和时区,是一种用于自动配置本地的时间和日期的机制,同时也通过无线网向移动设备提供运营商信息.NITZ是自从PHASE 2+ RELEASE 96 的GSM中的可选功能,经常被用来自动更新移动电话的系统时钟. NTP:NTP(Network Time Protocol)提供准确时间,首先要有准确的时间来源,这一时间应该是国际标准时间UTC. NTP获得UTC的时间来源可以是原子钟.天文台.卫星,

MySQL数据库时间设置自动添加时间和自动更新时间

说明: MySQL字段中设置时间字段自动添加创建时间和自动更新时间设置,设置字段类型为:timestamp 默认值设置为current_timestamp(),更新时间字段字段类型为:timestamp 默认值设置为 current_timestamp() ON UPDATE current_timestamp() SQL语法和实例 create table tb_name( join_time timestamp NULL DEFAULT current_timestamp(), update

mysql字段值自动更新时间

在生产环境中可能会出现,项目已经上线,但是更新时间的字段没有赋值,也就是说这条数据每次更新时,更新的时间依旧是null.为了解决这个问题,一般是将程序更新数据时,把更新时间给更新了.但是上线后更改程序需要重新升级,挺麻烦.现在可以通过修改更新时间的字段,来保证每次更新数据时,数据的更新时间自动更新. 在一个已经建好的表执行如下sql即可完成更新时间自动更新: ALTER TABLE checker_barcode MODIFY COLUMN update_time TIMESTAMP NOT N

mysql中自动更新时间CURRENT_TIMESTAMP

timestamp的两个属性:CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP http://blog.163.com/[email protected]/blog/static/2142429620122611356554/ http://www.cnblogs.com/yjf512/archive/2012/11/02/2751058.html http://blog.sina.com.cn/s/blog_49a665e10100cb52.html

Linux系统自动更新时间

转载自:http://www.cnblogs.com/choyaooo/p/8012923.html NTP服务器(上海) :ntp.api.bz    中国ntp服务器:cn.pool.ntp.org  pool.ntp.org    安装NTP客户端:    yum -y install ntp修改时区为Asia:    cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime     vim  /etc/sysconfig/clock     

CentOS 7 自动更新时间日期

# ntpdate time.nist.gov 或 # rdate -s time.nist.gov 下列服务器可用 time-nw.nist.gov

js自动更新时间+星期

<div class="top_bar" id="jnkc" height="28px"> <script> setInterval("jnkc.innerHTML=new Date().toLocaleString()+' 星期'+'日一二三四五六'.charAt(new Date().getDay());", 1000); </script> </div>