好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Yii Framwork在ActiveRecord自动化记录时间戳

有很多方法可以自动化设置在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(); }

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

查看更多关于Yii Framwork在ActiveRecord自动化记录时间戳的详细内容...

  阅读:43次