如何在ActiveRecord自动化记录时间戳

本文介绍了在Yii框架中如何利用ActiveRecord模型自动化设置时间戳。提供了两种方法:一是通过rules()函数定义验证规则,二是通过beforeSave()函数进行保存前的操作。这两种方法都能有效地为数据库表中的created和modified字段赋值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

摘要:有很多方法可以自动化设置在ActiveRecord模型中yii时间戳。下面介绍两种方法: 1.通过rules() 2.通过beforeSave()

 

  1. 通过rules()
  2. 通过beforeSave()

我们需要开始建立数据库表。

 

CREATE TABLE IF NOT EXISTS `Nodes` (
`id` bigint(20) NOT NULL auto_increment,
`title` varchar(255) NOT NULL,
`created` datetime NOT NULL,
`modified` datetime NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;



 按照下面的方法我们会Yii shell工具建立模型:

model Node Nodes

 第一种方法是通过你的模型的rules做到的。这里有个例子。

 1 /**
2 * @return array validation rules for model attributes.
3 */
4 public function rules()
5 {
6 return array(
7 array('title','length','max'=>255),
8 array('title, created, modified', 'required'),
9 array('modified','default',
10 'value'=>new CDbExpression('NOW()'),
11 'setOnEmpty'=>false,'on'=>'update'),
12 array('created,modified','default',
13 'value'=>new CDbExpression('NOW()'),
14 'setOnEmpty'=>false,'on'=>'insert')
15 );
16 }

你在最后看到两个规则,一个规则是在更新记录的时候改变属性值,另外一个规则是在创建记录的时候改变属性值。你也可以看到“new CDbExpression("NOW()")”声明。这通过“NOW()”的MySQL服务器,它不会被避开。MySQL可以翻译它作为一个声明,并不 是作为一个字符串。这意味着字段类型可以是其他日期/时间类型(时间戳、等等),它还可以工作。

另一个解决方案是通过beforeSave()方法,使用如下:

1 public function beforeSave() {
2 if ($this->isNewRecord)
3 $this->created = new CDbExpression('NOW()');
4 else
5 $this->modified = new CDbExpression('NOW()');
6
7 return parent::beforeSave();
8 }

这些都是简单和优雅解决这个问题的方法。



转载于:https://www.cnblogs.com/mrcoke/articles/2359334.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值