如何在ActiveRecord自动化记录时间戳
来源:互联网 发布:大司马淘宝店衣服 编辑:程序博客网 时间:2024/06/06 03:50
有很多方法可以自动化设置在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();}
这些都是简单和优雅解决这个问题的方法。
摘自:yiiFramework中文社区
- 如何在ActiveRecord自动化记录时间戳
- 如何在ActiveRecord自动化记录时间戳
- 如何在ActiveRecord自动化记录时间戳
- Yii 如何在ActiveRecord自动化记录时间戳
- Yii Framwork在ActiveRecord自动化记录时间戳
- ActiveRecord活动记录类
- Yii ActiveRecord用法记录备忘
- 如何记录kernel启动时间
- 如何给history命令记录加上时间戳
- ActiveRecord
- ActiveRecord
- ActiveRecord
- 记录学习hibernate4.3的日子之如何在hibernate中配置时间的<property/>
- ABBYY自动化文档处理是如何节省时间的
- ABBYY自动化文档处理是如何节省时间的
- java如何记录方法运行时间?
- ActiveRecord 如何高效地获取随机 records
- 在Castle ActiveRecord中使用NHibernate
- vc6下c++编译器通不过,c编译器通过
- Javamail in maven repository
- JPQL介绍
- x86和x64
- Android之涂鸦(简单的画图)
- 如何在ActiveRecord自动化记录时间戳
- win32 api 文件操作
- InstallSheild 拷贝文件夹
- 实现从内存中解压JPEG
- Android调用系统短信发送界面并预设接收号码、短信内容
- MOSFET与MOSFET驱动电路原理及应用
- SQLiteOpenHelper简介
- OnClick,OnClientClick和OnServerClick的区别
- 里程碑