如何在 ActiveRecord 自动化记录时间戳 [ 1.1 版本 ]
有很多方法可以自动化设置在ActiveRecord模型中yii时间戳。下面介绍两种方法:
- 通过rules()
- 通过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
创造crud功能我们需要这样:
crud Node
第一种方法是通过你的模型的rules做到的。这里有个例子。
/**
* @return array validation rules for model attributes.
*/
public function rules()
{
return array(
array('title','length','max'=>255),
array('title, created, modified', 'required'),
array('modified','default',
'value'=>new CDbExpression('NOW()'),
'setOnEmpty'=>false,'on'=>'update'),
array('created,modified','default',
'value'=>new CDbExpression('NOW()'),
'setOnEmpty'=>false,'on'=>'insert')
);
}
你在最后看到两个规则,一个规则是在更新记录的时候改变属性值,另外一个规则是在创建记录的时候改变属性值。你也可以看到“new CDbExpression("NOW()")”声明。这通过“NOW()”的MySQL服务器,它不会被避开。MySQL可以翻译它作为一个声明,并不是作为一个字符串。这意味着字段类型可以是其他日期/时间类型(时间戳、等等),它还可以工作。
另一个解决方案是通过beforeSave()方法,使用如下:
public function beforeSave() {
if ($this->isNewRecord)
$this->created = new CDbExpression('NOW()');
else
$this->modified = new CDbExpression('NOW()');
return parent::beforeSave();
}
这些都是简单和优雅解决这个问题的方法。
╃巡洋艦㊣ 北京
注册时间:2010-11-21
最后登录:2天前
在线时长:1685小时48分
最后登录:2天前
在线时长:1685小时48分
- 粉丝1370
- 金钱77583
- 威望845
- 积分102883
共 26 条评论
有道理,必须收藏起来~
http://www.yiiframework.com/extension/lcswfupload
我用的这个扩展,不错。
请教一下,多文件上传后图片的压缩是怎么处理的呢
怎么看不到
怎么还木有\r\n
public function behaviors() { return [ TimestampBehavior::className(), ]; }
http://www.yiichina.com/doc/api/2.0/yii-behaviors-timestampbehavior