网站地图    收藏   

主页 > 后端 > php资料库 >

Yii Framwork在ActiveRecord自动化记录时间戳_自学php网

来源:自学PHP网    时间:2014-12-04 22:12 作者: 阅读:

[导读] 有很多方法可以自动化设置在ActiveRecord模型中yii时间戳。下面介绍两种方法: 通过rules() 通过beforeSave() 我们需要开始建立数据库表。 CREATE TABLE IF NOT EXISTS `Nodes` ( `id` bigint(20) NOT NULL aut...

有很多方法可以自动化设置在ActiveRecord模型中yii时间戳。下面介绍两种方法:

  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

创造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();
}

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

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论