有些时候,我们可能需要记录某些列的更新时间,类似于rails的timestamps。手工一一处理稍显繁琐,于是将其抽取出来,写成了一个简单的plugin--column_timestamp,自动记录一些简单列的更新时间。
- 使用方法
1.将column_timestamp放到plugins目录。
2.在表中针对要记录更新时间的列建立一个新列:[column_name]_updated_at。
3.或者,在migration中使用:column_timestamp => true参数。例如:
def self.up
create_table :my_table do |t|
t.string :name
t.string :status,:column_timestamp => true
t.timestamps
end
end
这样,rails在执行migration的时候就会自动生成"status_updated_at"列。
4.OK。开始工作了。每当status的值改变,status_updated_at就会自动记录更新的时间。
5.如果要停止记录XXX_update_at,只需要在相应的model调用suppress_column_timestamps,例如:
class MyModel < ActiveRecord::Base
suppress_column_timestamps
...
end
- 版本问题
在2.0.2中通过。如果要在2.1+跑,可以将column_timestamp/vendor删除。并且注释column_timestamp/init.rb中的
require File.join(File.dirname(__FILE__),"/vendor/dirty_attr/init")
2008.10.15 23:59 星期三